• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            infinity

              C++博客 :: 首頁 :: 新隨筆 :: 聯(lián)系 :: 聚合  :: 管理 ::
              36 隨筆 :: 0 文章 :: 25 評(píng)論 :: 0 Trackbacks
            用16個(gè)為存儲(chǔ)棋盤的狀態(tài),BFS時(shí),每次枚舉所有可能的變換。




            Source Code

            Problem: 1753
            User: lovecanon
            Memory: 732K
            Time: 32MS
            Language: C
            Result: Accept
            • Source Code

            • #include<stdio.h>
              #include
              <string.h>
              unsigned 
              int queue[65536],vis[65536],step[65536];
              int main()
              {
                  unsigned 
              int i,j,k=1<<15,front=0,rear=0,cnt,tmp;
                  queue[
              ++rear]=0;
                  
              for(i=0;i<4;i++)
                  {
                      
              for(j=0;j<4;j++)
                      {    
                          queue[rear]
              +=(getchar()=='b')*k;
                          k
              >>=1;
                      }
                      getchar();
                  }
                  
              if(queue[rear]==0||queue[rear]==65535) {printf("0\n");return 0;}
                  step[queue[rear]]
              =0;
                  memset(vis,
              0,sizeof(vis[0]));
                  vis[queue[rear]]
              =1;
                  
              while(front<rear)
                  {
                      cnt
              =queue[++front];
                      
              for(i=0;i<4;i++)
                          
              for(j=0;j<4;j++)
                          {   
                              tmp
              =cnt;
                              
              if(i==0)  tmp^=0x1<<(11-4*i-j);
                              
              else if(i==3)  tmp^=0x1<<(19-4*i-j);
                              
              else {tmp^=0x1<<(19-4*i-j);tmp^=0x1<<(11-4*i-j);}
                              
              if(j==0)  tmp^=0x3<<(14-4*i);   
                              
              else if(j==3)  tmp^=0x3<<(12-4*i);
                              
              else tmp^=0x7<<(14-4*i-j);    
                              
              if(tmp==0||tmp==65535) {printf("%d\n",step[cnt]+1); return 0;}
                              
              else if(!vis[tmp])
                              {queue[
              ++rear]=tmp; step[tmp]=step[cnt]+1;vis[tmp]=1;}
                          }
                  }   
                  printf(
              "Impossible\n");
                  
              return 0;
              }

            posted on 2008-09-20 04:29 infinity 閱讀(1237) 評(píng)論(2)  編輯 收藏 引用 所屬分類: acm

            評(píng)論

            # re: poj 1753 Flip Game 2009-08-07 13:22 longniu
            妙!   回復(fù)  更多評(píng)論
              

            # re: poj 1753 Flip Game 2010-04-14 15:08 祝你好運(yùn)
            寫的確實(shí)是不錯(cuò)!如果能加上注釋就更好了!  回復(fù)  更多評(píng)論
              

            精品久久久久久国产牛牛app| 亚洲国产精品嫩草影院久久| 伊人久久大香线蕉亚洲| 国产精品99久久久精品无码| 久久精品国产亚洲AV香蕉| 91精品国产91久久久久久蜜臀| 久久伊人精品一区二区三区| 91久久九九无码成人网站| 久久免费视频一区| 国产精品久久久99| 91久久精一区二区三区大全| 伊人久久大香线蕉AV色婷婷色| 久久99国产综合精品免费| 国产A级毛片久久久精品毛片| 久久99精品国产| 色综合久久综精品| 国产激情久久久久影院小草| 亚洲а∨天堂久久精品9966| 精品视频久久久久| 亚洲精品乱码久久久久久中文字幕| 一级女性全黄久久生活片免费| 国产亚洲精品美女久久久| 日日狠狠久久偷偷色综合0| 色综合久久综合网观看| 久久国产欧美日韩精品| 国产欧美一区二区久久| 99精品国产综合久久久久五月天| 久久噜噜电影你懂的| 久久精品夜夜夜夜夜久久| 久久婷婷五月综合97色直播| 久久国产成人亚洲精品影院| 日本福利片国产午夜久久| 久久99国产综合精品免费| 嫩草伊人久久精品少妇AV| 99久久99这里只有免费费精品 | 久久精品人人做人人爽97| 色欲综合久久躁天天躁| 武侠古典久久婷婷狼人伊人| 99久久精品免费国产大片| 亚洲成人精品久久| 国产精久久一区二区三区|