POJ 1141

題意:給出一個表達式的子序列,要你填充這個序列,保證最終形成的序列長度最短,也就是添加的括號最少

這個子序列要遵循括號匹配的原則。

分析:轉移方程dp[i][j]=min(dp[i][k],dp[k+1][j]).i<=k<j.dp[1][1]=1;

dp[i][j]表示i到j最少添加幾個括號。同時用path[i][j]存插入括號的位置。遞歸輸出。

 1 #include<cstdio>
 2 #include<cstring>
 3 #include<cmath>
 4 #include<cstdlib>
 5 #include<iostream>
 6 #include<algorithm>
 7 #include<vector>
 8 #include<map>
 9 #include<queue>
10 #include<stack>
11 #include<string>
12 #include<set>
13 #define eps 1e-6
14 #define LL long long
15 #define clc(a,b) memset(a,b,sizeof(a))
16 const int maxd=1e6+10;
17 using namespace std;
18 const int MAX = 110;
19 const int INF = 0x3f3f3f3f;
20 const int mod=258280327;
21 
22 int dp[MAX][MAX],path[MAX][MAX],len;
23 char str[MAX];
24 
25 void output(int st ,int endd)
26 {
27     if(st>endd)
28         return ;
29     else if(st==endd)
30     {
31         if(str[st]=='('||str[st]==')')
32             printf("()");
33         else
34         printf("[]");
35     }
36     else if(path[st][endd]==-1)
37     {
38         printf("%c",str[st]);
39         output(st+1,endd-1);
40         printf("%c",str[endd]);
41     }
42     else
43     {
44         output(st,path[st][endd]);
45         output(path[st][endd]+1,endd);
46     }
47 }
48 
49 int main()
50 {
51 
52     while(gets(str)!=NULL)
53     {
54         clc(dp,0);
55         len=strlen(str);
56         for(int i=0;i<len;i++)
57             dp[i][i]=1;
58         for(int l=1;l<len;l++)
59         {
60             for(int i=0;i<=len-l;i++)
61             {
62                 int j=i+l;
63                 if(str[i]=='('&&str[j]==')'||str[i]=='['&&str[j]==']')
64                 {
65                     dp[i][j]=dp[i+1][j-1];
66                     path[i][j]=-1;
67                 }
68                 else
69                     dp[i][j]=INF;
70                 for(int k=i;k<=j-1;k++)
71                 {
72                     if(dp[i][j]>dp[i][k]+dp[k+1][j])
73                     {
74                         dp[i][j]=dp[i][k]+dp[k+1][j];
75                         path[i][j]=k;
76                     }
77                 }
78             }
79         }
80         output(0,len-1);
81         printf("\n");
82     }
83     return 0;
84 }
View Code

?

轉載于:https://www.cnblogs.com/ITUPC/p/4820389.html

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/397486.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/397486.shtml
英文地址,請注明出處:http://en.pswp.cn/news/397486.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

PHP array_count_values() 函數用于統計數組中所有值出現的次數。

定義和用法 array_count_values() 函數用于統計數組中所有值出現的次數。 本函數返回一個數組&#xff0c;其元素的鍵名是原數組的值&#xff0c;鍵值是該值在原數組中出現的次數。 語法 array_count_values(array) 參數 描述 array 必需。規定輸入的數組。 例子 <?php …

SpringDay01

一&#xff1a;什么是Spring。 簡單的理解就是一個可以裝web層&#xff0c; service層&#xff0c; dao層&#xff0c;這三層對象的容器。 二&#xff1a;Spring搭建 1.導包&#xff1a;核心四個包和log4j兩個包 2.注冊對象&#xff1a;User類 3.書寫配置注冊對象到容器 a>導…

bom_clear.php,thinkphp清除BOM方法

該樓層疑似違規已被系統折疊 隱藏此樓查看此樓在utf-8編碼文件中BOM在文件頭部&#xff0c;占用三個字節&#xff0c;用來標示該文件屬于utf-8編碼&#xff0c;現在已經有很多軟件識別bom頭&#xff0c;但是還有些不能識別bom頭&#xff0c;比如PHP就不能識別bom頭&#xff0c;…

(算法)Trapping Rain Water I

題目&#xff1a; Given n non-negative integers representing an elevation map where the width of each bar is 1, compute how much water it is able to trap after raining. For example, Given [0,1,0,2,1,0,1,3,2,1,2,1], return 6. 思路&#xff1a; 題目的意思是說&…

字符數組拷貝與strcpy函數

代碼&#xff1a; char str1[10],str2[10];for (int i0;i<10;i){str1[i]a;}strcpy(str2,str1); 讓找出錯誤的地方。 先來看下strcpy函數&#xff1a; 使用格式&#xff1a;char* strcmp&#xff08;char* buffer&#xff0c;char*str&#xff09;功 能: 把從str地址開始且含…

java中的NAN和INFINITY

2019獨角獸企業重金招聘Python工程師標準>>> java浮點數運算中有兩個特殊的情況&#xff1a;NAN、INFINITY。 1、INFINITY&#xff1a; 在浮點數運算時&#xff0c;有時我們會遇到除數為0的情況&#xff0c;那java是如何解決的呢&#xff1f; 我們知道&#xff0c;在…

php框架tp5工作流程,tp5框架流程

之前沒怎么了解過&#xff0c;但用過TP3.2.網上查了下說是區別很大&#xff0c;特此記錄下。流程&#xff1a;1.入口文件默認是 public目錄下的index.php// 定義應用目錄define(APP_PATH, __DIR__ . /../application/);// 加載框架引導文件require __DIR__ . /../thinkphp/star…

有移動規則2

import org.robochina.airobot.tank.*; import org.robochina.math.*; import java.awt.geom.*; import java.util.*;/*** 這個類對應一個機器人&#xff0c;根據需要實現相應的Action處理函數&#xff0c;* 就可以訂制自己的機器人。*/ public class Text extends SimpleRobot…

Troubleshooting(三):網絡

2019獨角獸企業重金招聘Python工程師標準>>> 前言 在 Troubleshooting 過程中&#xff0c;檢查完進程信息后&#xff0c;接下來就是排查網絡情況的時候了&#xff0c;初略翻過《TCP/IP 詳解卷一&#xff1a;協議》這本書&#xff0c;簡直跟看《深入理解 Linux 內核》…

SqlServer 備份還原教程

看了眾多教程&#xff0c;自己也寫個增強記憶&#xff0c;錯誤地方麻煩指出。 ———————————————————————-備份——————————————————————– 1.打開數據庫&#xff0c;成功連接 2.找到要備份的數據庫&#xff0c;圖中演示備份數據庫te…

php通過實現excel導入,php實現excel導入數據

表單頁面 if($_POST [import]"導入數據 "){$leadExcel$_POST[leadExcel];//echo $leadExcel;die;if($leadExcel "true"){//echo "OK";die();//獲取上傳的文件名$filename $_FILES[inputExcel][name];//上傳到服務器上的臨時文件名$tmp_name $…

深入理解計算機系統----讀書筆記

第二部分 信息的表示和處理 信息存儲&#xff1a; 二進制&#xff08;0101001&#xff09;&#xff0c; 八進制&#xff0c;十六進制&#xff08;0x32FD&#xff09; 字&#xff08;word size&#xff09;指明整數和指針數據的標稱大小&#xff08;normal size&#xff09;&…

FiddlerScript-常用總結

沒有用過Fiddler的人應該對FiddlerScript沒啥感觸&#xff0c;我是真心覺得FiddlerScript對測試有一定的幫助哈。在web前端開發過程中&#xff0c;Fiddler是最常用的一款調試工具&#xff0c;那對于測試來說&#xff0c;對測試來說也是一大利器。在大多數情況下&#xff0c;通過…

OpenStack-Zun 使用

Zun組件簡介 Zun是Openstack中提供容器管理服務的組件&#xff0c;于2016年6月建立。Zun的目標是提供統一的Openstack API用于啟動和管理容器&#xff0c;支持多種容器技術。Zun原來稱為Higgins&#xff0c;后改名為Zun。 Zun計劃支持多種容器技術&#xff0c;Docker&#xff0…

【優雅代碼】深入淺出 妙用Javascript中apply、call、bind

這篇文章實在是很難下筆&#xff0c;因為網上相關文章不勝枚舉。 巧合的是前些天看到阮老師的一篇文章的一句話&#xff1a; “對我來說&#xff0c;博客首先是一種知識管理工具&#xff0c;其次才是傳播工具。我的技術文章&#xff0c;主要用來整理我還不懂的知識。我只寫那些…

PHP筆記隨筆

1.CSS控制頁面文字不能復制&#xff1a; body{-webkit-user-select:none;} 2.【php過濾漢字和非漢字】 $sc"aaad....##--__i漢字過濾"; //iconv("UTF-8","GB2312",$sc);utf-8轉碼 echo $temperegi_replace("[^\x80-\xff]",""…

qt linux 添加庫文件路徑,Linux下Qt調用共享庫文件.so

jvm--4垃圾收集6. 垃圾收集GC (1)當需要排查各種內存溢出,內存泄漏等問題,當GC成為系統達到更高性能的瓶頸時,我們就需要對這些自動化的GC進行監控和調節. (2)PC計數器.本地方法棧.虛擬機棧,隨方法或者線 ...GET和POSTAjax與Comet 1. Ajax Asynchronous Javascriptxml :能夠向服…

js進階 14-8 表單序列化函數serializeArray()和serialize()的區別是什么

js進階 14-8 表單序列化函數serializeArray()和serialize()的區別是什么 一、總結 一句話總結&#xff1a;兩者都是對表單進行序列化&#xff0c;serializeArray()返回的是json對象&#xff0c;serialize()返回的是json形式的字符串&#xff0c;使用起來都是一樣的 1、$&#x…

HDU 2842 Chinese Rings(矩陣高速功率+遞歸)

職務地址&#xff1a;HDU 2842 這個游戲是一個九連環的游戲。 如果當前要卸下前n個環。由于要滿足前n-2個都卸下&#xff0c;所以要先把前n-2個卸下。須要f(n-2)次。然后把第n個卸下須要1次&#xff0c;然后這時候要卸下第n-1個。然后此時前n-2個都已經被卸下了。這時候把前n-2…

硬鏈接與軟連接

linux系統硬鏈接和軟連接&#xff1a; 1文件都由文件名和數據組成&#xff0c;在linux中文件被分為兩個部分&#xff1a;用戶數據和元數據。用戶數據&#xff1a;即文件數據塊&#xff0c;記錄真實數據的地方。元數據&#xff1a;文件的附加屬性&#xff0c;記錄文件的大小&…