码迷,mamicode.com
首页 > 其他好文 > 详细

HDU 4915 Parenthese sequence

时间:2014-08-07 12:59:10      阅读:237      评论:0      收藏:0      [点我收藏+]

标签:style   blog   http   color   os   io   数据   for   

题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4915

解题报告:从前往后遍历一次,每次判断‘)‘的数目是不是满足 n < (i +1)/ 2,从后往前遍历一次,每次判断‘(‘的数目是不是满足 n <= (len - i) / 2;

这样就可以判断出这个序列是否存在匹配的序列。接下来就是判断是Many还是Unique的情况,因为数据是10的六次方,所以遇到问号改成‘(‘ 或‘)‘暴力判断是不行的,但是我们可以判断出只要(和)的数目小于等于len / 2而且有三个连续的?那句是Many,否则再进行暴力判断,这样就可以大大减小时间复杂度。

bubuko.com,布布扣
 1 #include<cstdio>
 2 #include<iostream>
 3 #include<cstring>
 4 #include<algorithm>
 5 using namespace std;
 6 const int maxn = 1000000+5;
 7 char str[maxn];
 8 
 9 int judge(char* str)
10 {
11     int len = strlen(str);
12     int a = 0,b = 0;
13     for(int i = 0,j = len- 1;i < len,j >= 0;++i,--j)
14     {
15         if(str[i] == )) a++;
16         if(str[j] == () b++;
17         if(a >  (i + 1) / 2) return 0;
18         if(b > (len - j) / 2) return 0;
19     }
20     return 1;
21 }
22 int main()
23 {
24 //    freopen("1005.in","r",stdin);
25     int T = 0;
26     while(scanf("%s",str)!=EOF)
27     {
28         T++;
29         int ans;
30         ans = judge(str);
31         int l = strlen(str);
32         if(l & 1) ans = 0;
33         if(!ans)
34         {
35             puts("None");
36             continue;
37         }
38         int len =  strlen(str);
39         int a = 0,b = 0,c = 0,f = 0,M = 0;
40         for(int i = 0;i < len;++i)
41         {
42             if(str[i] == () a++;
43             if(str[i] == )) b++;
44             if(str[i] == ?)
45             {
46                 f++;
47                 c++;
48             }
49             else
50             {
51                 M = max(M,f);
52                 f = 0;
53             }
54         }
55         if(a >= len / 2 || b >= len / 2 || c <= 1)
56         {
57             puts("Unique");
58             continue;
59         }
60         if(M >= 3)
61         {
62             puts("Many");
63             continue;
64         }
65         ans = 0;
66         for(int i = 0;i < len;++i)
67         if(str[i] == ?)
68         {
69             int tt = 0;
70             str[i] = (;
71             tt += judge(str);
72             str[i] = );
73             tt += judge(str);
74             if(tt == 2)
75             {
76                 ans = 1;
77                 break;
78             }
79             str[i] = ?;
80         }
81         printf(ans? "Many\n":"Unique\n");
82     }
83     return 0;
84 }
View Code

 

HDU 4915 Parenthese sequence,布布扣,bubuko.com

HDU 4915 Parenthese sequence

标签:style   blog   http   color   os   io   数据   for   

原文地址:http://www.cnblogs.com/xiaxiaosheng/p/3896644.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!