#includechars[1000005],tp[1000005];intl;intpd(){intzuo,you,num,i;num=0;zuo=0;you=" />

亚洲免费在线-亚洲免费在线播放-亚洲免费在线观看-亚洲免费在线观看视频-亚洲免费在线看-亚洲免费在线视频

hdu 4915 Parenthese sequence 多校第五場

系統 1934 0

推斷一個序列是否是有效是簡單的。

可是推斷序列是不是有多個解會出問題。

那么從i=0 ~l

假設讀到問號,推斷該問號成為(能否有效,該問號為)是否有效。

假設都有效,則必有多個解。

假設都無效,則無解。

假設一個有效,則把問號改成有效的括號。

代碼實現例如以下

      #include<stdio.h>
#include<string.h>
char s[1000005],tp[1000005];
int l;
int pd()
{
    int zuo,you,num,i;
    num=0;
    zuo=0;
    you=0;
    for(i=0;i<l;i++)
    {
       num++;
       if(num==1)
       {
        if(tp[i]=='?')
          tp[i]='(';

       }
                
                if(tp[i]=='(') zuo++;
                if(tp[i]==')') you++;
                if(you>num/2) 
                {
                    return 0;
                }
                if(num%2==0)
                {
                    if(you==num/2) 
                    {
                        zuo=0;
                        you=0;
                        num=0;
                    }
                }
        
    }
    if(zuo>num/2) return 0;
    num=0; 
    zuo=0;
    you=0;
            for(i=l-1;i>=0;i--)
            {
                num++;
                if(num==1)
                {
                    if(tp[i]=='?')
                    tp[i]=')';
                }
                if(tp[i]=='(') zuo++;
                if(tp[i]==')') you++;
                if(zuo>num/2) 
                {
                    return 0;
                }
                if(num%2==0)
                {
                    if(zuo==num/2) 
                    {
                        zuo=0;
                        you=0;
                        num=0;
                    }
                }
                
            }
            if(you>num/2) return 0;
            return 1;
    
}
int main()
{
   int zuo,you,x,y,i;
   while(scanf("%s",s)!=EOF)
   {
       l=strlen(s);
       if(l%2==1)
       {
           printf("None\n");
           continue;
    }
    
    else
    {
     strcpy(tp,s);
  x=pd();
  if(x==0)
  {
   printf("None\n");
   continue;
  }
        for(i=0;i<l;i++)
        {
          if(s[i]=='?')
          {
              strcpy(tp,s);
              tp[i]=')';
              x=pd();
              strcpy(tp,s);
              tp[i]='(';
              y=pd();
              if(x+y==2) 
              {printf("Many\n");
              break;
              }
              if(x+y==0)
              {
                  printf("None\n");
                  break;
              }
              if(x==1)
              s[i]=')';
              else 
              s[i]='(';             
            }    
            
        } 
        if(i==l)
            {
                printf("Unique\n");
                
            }
    } 
   }
   return 0;    
}

 

    


?

hdu 4915 Parenthese sequence 多校第五場


更多文章、技術交流、商務合作、聯系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號聯系: 360901061

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對您有幫助就好】

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長會非常 感謝您的哦!!!

發表我的評論
最新評論 總共0條評論
主站蜘蛛池模板: 国产在线激情视频 | 这里只有精品视频在线 | 免费播放美女一级毛片 | 日本不卡一区二区三区 最新 | 天天射日日 | 99爱网站 | 亚洲无成人网77777 | 国产亚洲第一精品社区麻豆 | 婷婷色综合久久 | 国产成人8x视频一区二区 | 久久99蜜桃精品久久久久小说 | 女人十八一级毛片 | 色综合久久中文字幕综合网 | 久久久久久久久中文字幕 | 888米奇色狠狠俺去啦 | 99热这里只有精品99 | 亚洲码和乱人伦中文一区 | 亚洲综合射| 国产一级持黄大片99久久 | 久久久久夜夜夜精品国产 | 五月天丁香六月欧美综合 | 综合久久精品 | 97精品在线播放 | 天天色综合图片 | 亚洲综合久久久久久中文字幕 | 欧美毛片一级 | 久久综合九色综合97伊人麻豆 | 免费播放美女一级毛片 | 国产一级精品毛片 | 狠狠色噜噜狠狠米奇777 | 99精品国产一区二区青青牛奶 | 伊人久久99亚洲精品久久频 | 成人交性视频免费看 | 免费播放毛片 | 天天操一操 | 亚洲激情视频在线播放 | 爱爱免费网址 | 国产在线视频凹凸分类 | 福利在线影院 | 久草最新网址 | 欧美成人久久久 |