• <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>

            置頂隨筆

            [置頂]關于五子棋代碼。求指導!!!

            人人對戰:


            #include<iostream>
            using namespace std;
            void wz()
            {
             cout<<"下面開始五子棋比賽,一號選手用方塊符號,二號用心型符號:"<<endl<<endl;
             for(int i=3;i>0;i--)
             {
              cout<<i<<"  ";
             }
             cout<<"開始-----------"<<endl<<endl;
            }

            int hs()
            {
             int x,y,i=0,j=1;
                   char d[80][80];
                //初始化---
                   for(x=0;x<25;x+=3)
                   {
                          for(y=0;y<80;y+=3)
                          {
                                 d[x][y]='+';
                 }
                }

                 //第一行數字--
                for(x=0;x<10;x++)
                       cout<<x<<"  ";
                for(x=10;x<27;x++)
                 cout<<x<<" ";
                cout<<endl;

            //輸出棋盤--
                for(x=0;x<25;x+=3)
                   {
                 cout<<j<<"  ";j++;
                          for(y=0;y<76;y+=3)
                          {
                 
                                 cout<<d[x][y]<<"  ";
                 }
                 cout<<endl;
                }
               

             
              

             while(1)
             {
              
              int a,b;
              if(i%2==0)
              cout<<"由玩家一下棋:"<<endl;
              else
               cout<<"由玩家二下棋:"<<endl;

              cin>>a>>b;
              if(i%2==1)
              {
               if(d[(a-1)*3][(b-1)*3]=='+')
                     d[(a-1)*3][(b-1)*3]=3;
               else
               {
                cout<<"-----------------------------不能覆蓋棋子:"<<endl;
                continue;
               }
              }
              else
              {
               if(d[(a-1)*3][(b-1)*3]=='+')
               d[(a-1)*3][(b-1)*3]=1;
               else
               {
                cout<<"-----------------------------不能覆蓋棋子:"<<endl;
                continue;
               }
              }
              i++;
              j=1;
              //第一行數字---
             for(x=0;x<10;x++)
                       cout<<x<<"  ";
                for(x=10;x<27;x++)
                 cout<<x<<" ";
                cout<<endl;

                for(x=0;x<25;x+=3)
                   {
                 cout<<j<<"  ";j++;
                          for(y=0;y<76;y+=3)
                          {
                 
                                 cout<<d[x][y]<<"  ";
                 }
                 cout<<endl;
                }
            //判斷是否是五個
                if(//橫著
                 d[(a-1)*3][(b-1)*3]==1&&d[(a-1)*3][(b)*3]==1&&d[(a-1)*3][(b+1)*3]==1&&d[(a-1)*3][(b+2)*3]==1&&d[(a-1)*3][(b+3)*3]==1
                 ||d[(a-1)*3][(b-2)*3]==1&&d[(a-1)*3][(b-1)*3]==1&&d[(a-1)*3][(b)*3]==1&&d[(a-1)*3][(b+1)*3]==1&&d[(a-1)*3][(b+2)*3]==1
                 ||d[(a-1)*3][(b-3)*3]==1&&d[(a-1)*3][(b-2)*3]==1&&d[(a-1)*3][(b-1)*3]==1&&d[(a-1)*3][(b)*3]==1&&d[(a-1)*3][(b+1)*3]==1
                 ||d[(a-1)*3][(b-4)*3]==1&&d[(a-1)*3][(b-3)*3]==1&&d[(a-1)*3][(b-2)*3]==1&&d[(a-1)*3][(b-1)*3]==1&&d[(a-1)*3][(b)*3]==1
                 ||d[(a-1)*3][(b-5)*3]==1&&d[(a-1)*3][(b-4)*3]==1&&d[(a-1)*3][(b-3)*3]==1&&d[(a-1)*3][(b-2)*3]==1&&d[(a-1)*3][(b-1)*3]==1
                 //從左上到右下
                 ||d[(a-1)*3][(b-1)*3]==1&&d[a*3][b*3]==1&&d[(a+1)*3][(b+1)*3]==1&&d[(a+2)*3][(b+2)*3]==1&&d[(a+3)*3][(b+3)*3]==1
                 ||d[(a-2)*3][(b-2)*3]==1&&d[(a-1)*3][(b-1)*3]==1&&d[a*3][b*3]==1&&d[(a+1)*3][(b+1)*3]==1&&d[(a+2)*3][(b+2)*3]==1
                 ||d[(a-3)*3][(b-3)*3]==1&&d[(a-2)*3][(b-2)*3]==1&&d[(a-1)*3][(b-1)*3]==1&&d[a*3][b*3]==1&&d[(a+1)*3][(b+1)*3]==1
                 ||d[(a-4)*3][(b-4)*3]==1&&d[(a-3)*3][(b-3)*3]==1&&d[(a-2)*3][(b-2)*3]==1&&d[(a-1)*3][(b-1)*3]==1&&d[a*3][b*3]==1
                 ||d[(a-5)*3][(b-5)*3]==1&&d[(a-4)*3][(b-4)*3]==1&&d[(a-3)*3][(b-3)*3]==1&&d[(a-2)*3][(b-2)*3]==1&&d[(a-1)*3][(b-1)*3]==1
                 //從右上到左下
                 ||d[(a-1)*3][(b-1)*3]==1&&d[(a-2)*3][b*3]==1&&d[a-3][b+1]==1&&d[a-4][b+2]==1&&d[a-5][b+3]==1
                 ||d[a*3][(b-2)*3]==1&&d[(a-1)*3][(b-1)*3]==1&&d[(a-2)*3][b*3]==1&&d[(a-3)*3][(b+1)*3]==1&&d[(a-4)*3][(b+2)*3]==1
                 ||d[(a+1)*3][(b-3)*3]==1&&d[a*3][(b-2)*3]==1&&d[(a-1)*3][(b-1)*3]==1&&d[(a-2)*3][b*3]==1&&d[(a-3)*3][(b+1)*3]==1
                 ||d[(a+2)*3][(b-4)*3]==1&&d[(a+1)*3][(b-3)*3]==1&&d[a*3][(b-2)*3]==1&&d[(a-1)*3][(b-1)*3]==1&&d[(a-2)*3][b*3]==1
                 ||d[(a+3)*3][(b-5)*3]==1&&d[(a+2)*3][(b-4)*3]==1&&d[(a+1)*3][(b-3)*3]==1&&d[a*3][(b-2)*3]==1&&d[(a-1)*3][(b-1)*3]==1
                 //豎著
                    ||d[(a-1)*3][(b-1)*3]==1&&d[a*3][(b-1)*3]==1&&d[(a+1)*3][(b-1)*3]==1&&d[(a+2)*3][(b-1)*3]==1&&d[(a+3)*3][(b-1)*3]==1
                 ||d[(a-2)*3][(b-1)*3]==1&&d[(a-1)*3][(b-1)*3]==1&&d[a*3][(b-1)*3]==1&&d[(a+1)*3][(b-1)*3]==1&&d[(a+2)*3][(b-1)*3]==1
                 ||d[(a-3)*3][(b-1)*3]==1&&d[(a-2)*3][(b-1)*3]==1&&d[(a-1)*3][(b-1)*3]==1&&d[a*3][(b-1)*3]==1&&d[(a+1)*3][(b-1)*3]==1
                 ||d[(a-4)*3][(b-1)*3]==1&&d[(a-3)*3][(b-1)*3]==1&&d[(a-2)*3][(b-1)*3]==1&&d[(a-1)*3][(b-1)*3]==1&&d[a*3][(b-1)*3]==1
                 ||d[(a-5)*3][(b-1)*3]==1&&d[(a-4)*3][(b-1)*3]==1&&d[(a-3)*3][(b-1)*3]==1&&d[(a-2)*3][(b-1)*3]==1&&d[(a-1)*3][(b-1)*3]==1
                 )
                {
                 cout<<endl<<"玩家一獲勝"<<endl;break;
                }

                if(//橫著
                 d[(a-1)*3][(b-1)*3]==3&&d[(a-1)*3][(b)*3]==3&&d[(a-1)*3][(b+1)*3]==3&&d[(a-1)*3][(b+2)*3]==3&&d[(a-1)*3][(b+3)*3]==3
                 ||d[(a-1)*3][(b-2)*3]==3&&d[(a-1)*3][(b-1)*3]==3&&d[(a-1)*3][(b)*3]==3&&d[(a-1)*3][(b+1)*3]==3&&d[(a-1)*3][(b+2)*3]==3
                 ||d[(a-1)*3][(b-3)*3]==3&&d[(a-1)*3][(b-2)*3]==3&&d[(a-1)*3][(b-1)*3]==3&&d[(a-1)*3][(b)*3]==3&&d[(a-1)*3][(b+1)*3]==3
                 ||d[(a-1)*3][(b-4)*3]==3&&d[(a-1)*3][(b-3)*3]==3&&d[(a-1)*3][(b-2)*3]==3&&d[(a-1)*3][(b-1)*3]==3&&d[(a-1)*3][(b)*3]==3
                 ||d[(a-1)*3][(b-5)*3]==3&&d[(a-1)*3][(b-4)*3]==3&&d[(a-1)*3][(b-3)*3]==3&&d[(a-1)*3][(b-2)*3]==3&&d[(a-1)*3][(b-1)*3]==3
                 //從左上到右下
                 ||d[(a-1)*3][(b-1)*3]==3&&d[a*3][b*3]==3&&d[(a+1)*3][(b+1)*3]==3&&d[(a+2)*3][(b+2)*3]==3&&d[(a+3)*3][(b+3)*3]==3
                 ||d[(a-2)*3][(b-2)*3]==3&&d[(a-1)*3][(b-1)*3]==3&&d[a*3][b*3]==3&&d[(a+1)*3][(b+1)*3]==3&&d[(a+2)*3][(b+2)*3]==3
                 ||d[(a-3)*3][(b-3)*3]==3&&d[(a-2)*3][(b-2)*3]==3&&d[(a-1)*3][(b-1)*3]==3&&d[a*3][b*3]==3&&d[(a+1)*3][(b+1)*3]==3
                 ||d[(a-4)*3][(b-4)*3]==3&&d[(a-3)*3][(b-3)*3]==3&&d[(a-2)*3][(b-2)*3]==3&&d[(a-1)*3][(b-1)*3]==3&&d[a*3][b*3]==3
                 ||d[(a-5)*3][(b-5)*3]==3&&d[(a-4)*3][(b-4)*3]==3&&d[(a-3)*3][(b-3)*3]==3&&d[(a-2)*3][(b-2)*3]==3&&d[(a-1)*3][(b-1)*3]==3
                 //從右上到左下
                 ||d[(a-1)*3][(b-1)*3]==3&&d[(a-2)*3][b*3]==3&&d[a-3][b+1]==3&&d[a-4][b+2]==3&&d[a-5][b+3]==3
                 ||d[a*3][(b-2)*3]==3&&d[(a-1)*3][(b-1)*3]==3&&d[(a-2)*3][b*3]==3&&d[(a-3)*3][(b+1)*3]==3&&d[(a-4)*3][(b+2)*3]==3
                 ||d[(a+1)*3][(b-3)*3]==3&&d[a*3][(b-2)*3]==3&&d[(a-1)*3][(b-1)*3]==3&&d[(a-2)*3][b*3]==3&&d[(a-3)*3][(b+1)*3]==3
                 ||d[(a+2)*3][(b-4)*3]==3&&d[(a+1)*3][(b-3)*3]==3&&d[a*3][(b-2)*3]==3&&d[(a-1)*3][(b-1)*3]==3&&d[(a-2)*3][b*3]==3
                 ||d[(a+3)*3][(b-5)*3]==3&&d[(a+2)*3][(b-4)*3]==3&&d[(a+1)*3][(b-3)*3]==3&&d[a*3][(b-2)*3]==3&&d[(a-1)*3][(b-1)*3]==3
                 //豎著
                    ||d[(a-1)*3][(b-1)*3]==3&&d[a*3][(b-1)*3]==3&&d[(a+1)*3][(b-1)*3]==3&&d[(a+2)*3][(b-1)*3]==3&&d[(a+3)*3][(b-1)*3]==3
                 ||d[(a-2)*3][(b-1)*3]==3&&d[(a-1)*3][(b-1)*3]==3&&d[a*3][(b-1)*3]==3&&d[(a+1)*3][(b-1)*3]==3&&d[(a+2)*3][(b-1)*3]==3
                 ||d[(a-3)*3][(b-1)*3]==3&&d[(a-2)*3][(b-1)*3]==3&&d[(a-1)*3][(b-1)*3]==3&&d[a*3][(b-1)*3]==3&&d[(a+1)*3][(b-1)*3]==3
                 ||d[(a-4)*3][(b-1)*3]==3&&d[(a-3)*3][(b-1)*3]==3&&d[(a-2)*3][(b-1)*3]==3&&d[(a-1)*3][(b-1)*3]==3&&d[a*3][(b-1)*3]==3
                 ||d[(a-5)*3][(b-1)*3]==3&&d[(a-4)*3][(b-1)*3]==3&&d[(a-3)*3][(b-1)*3]==3&&d[(a-2)*3][(b-1)*3]==3&&d[(a-1)*3][(b-1)*3]==3
                 )
                {
               cout<<endl<<"玩家二獲勝"<<endl;break;
                }
             }
             return 0;
            }
            int main()
            {
             char a;
             wz();
             hs();
             while(1)
              {
              cout<<"按P重新開始:";
              cin>>a;
              if(a=='p')
               hs();
              else
               break;
              }
             return 0; 
            }




            人機對戰暫時沒想出來,有知道的希望指教一下!!感激----

            posted @ 2012-04-12 23:48 迎風而立 閱讀(1558) | 評論 (5)編輯 收藏

            [置頂]關于移位運算符和取反運算符的一點感悟

            今天在學習移位運算符和取反運算符的時候,發現一些問題!現在呢在這里說一下自己的感悟!

            先看下面一道 取反和移位相結合的問題


            #include<stdio.h>
            int main()
            {
             char a=0x11;
             char b;
             b=~a<<2;
             printf("%d\n",b);
             b=~(a<<2);
             printf("%d\n",b);
             b=~a>>2;
             printf("%d\n",b);
             b=~(a>>2);
             printf("%d\n",b);
             return 0;
            }

             

            輸出結果是:

            -72
            -69
            -5
            -5

             

            剛開始在想為什么相同的操作(只是移位方向不同),為什么上面兩個結果不一樣,而下面兩個結果卻是一樣的呢。有些人在疑問是不是因為下面兩個表達式都是先移位后取反的呢?我可以肯定不是這樣的,但是不能解釋這個結果。這個問題我糾結了半天!  不過對下面的知識了解之后便豁然開朗了。

            移位運算符分為左移運算符和右移運算符。
            當對一個數執行左移運算的時候,右邊的空位是用0補齊。
            而當對一個數執行右移運算的時候,左邊的空位是用符號位補齊的(這是我之前沒注意的地方,慚愧)。

             

            解體步驟如下:


            a=0x11=0001 0001

            ~a=1110 1110
            a<<2=0100 0100
            a>>2=0000 0100


            ~a<<2=1011 1000 
            現在 1011 1000是補碼,轉化成原碼之后是
            1100 1000=-72  -72是十進制

            ~(a<<2)=0100 0100
            轉化為原碼之后是 1100 0101=-69


            ~a>>2=1111 1011(注意現在是用1補齊的,因為~a的符號位是1)
            轉化為原碼之后是  1000 0101=-5


            ~(a>>2)=1111 1011
            轉化為原碼之后是  1000 0101=-5


            明白之后心情很好,所以在這里分享一下。呵呵

            posted @ 2012-04-08 21:29 迎風而立 閱讀(1695) | 評論 (2)編輯 收藏

            2012年4月12日

            關于五子棋代碼。求指導!!!

            人人對戰:


            #include<iostream>
            using namespace std;
            void wz()
            {
             cout<<"下面開始五子棋比賽,一號選手用方塊符號,二號用心型符號:"<<endl<<endl;
             for(int i=3;i>0;i--)
             {
              cout<<i<<"  ";
             }
             cout<<"開始-----------"<<endl<<endl;
            }

            int hs()
            {
             int x,y,i=0,j=1;
                   char d[80][80];
                //初始化---
                   for(x=0;x<25;x+=3)
                   {
                          for(y=0;y<80;y+=3)
                          {
                                 d[x][y]='+';
                 }
                }

                 //第一行數字--
                for(x=0;x<10;x++)
                       cout<<x<<"  ";
                for(x=10;x<27;x++)
                 cout<<x<<" ";
                cout<<endl;

            //輸出棋盤--
                for(x=0;x<25;x+=3)
                   {
                 cout<<j<<"  ";j++;
                          for(y=0;y<76;y+=3)
                          {
                 
                                 cout<<d[x][y]<<"  ";
                 }
                 cout<<endl;
                }
               

             
              

             while(1)
             {
              
              int a,b;
              if(i%2==0)
              cout<<"由玩家一下棋:"<<endl;
              else
               cout<<"由玩家二下棋:"<<endl;

              cin>>a>>b;
              if(i%2==1)
              {
               if(d[(a-1)*3][(b-1)*3]=='+')
                     d[(a-1)*3][(b-1)*3]=3;
               else
               {
                cout<<"-----------------------------不能覆蓋棋子:"<<endl;
                continue;
               }
              }
              else
              {
               if(d[(a-1)*3][(b-1)*3]=='+')
               d[(a-1)*3][(b-1)*3]=1;
               else
               {
                cout<<"-----------------------------不能覆蓋棋子:"<<endl;
                continue;
               }
              }
              i++;
              j=1;
              //第一行數字---
             for(x=0;x<10;x++)
                       cout<<x<<"  ";
                for(x=10;x<27;x++)
                 cout<<x<<" ";
                cout<<endl;

                for(x=0;x<25;x+=3)
                   {
                 cout<<j<<"  ";j++;
                          for(y=0;y<76;y+=3)
                          {
                 
                                 cout<<d[x][y]<<"  ";
                 }
                 cout<<endl;
                }
            //判斷是否是五個
                if(//橫著
                 d[(a-1)*3][(b-1)*3]==1&&d[(a-1)*3][(b)*3]==1&&d[(a-1)*3][(b+1)*3]==1&&d[(a-1)*3][(b+2)*3]==1&&d[(a-1)*3][(b+3)*3]==1
                 ||d[(a-1)*3][(b-2)*3]==1&&d[(a-1)*3][(b-1)*3]==1&&d[(a-1)*3][(b)*3]==1&&d[(a-1)*3][(b+1)*3]==1&&d[(a-1)*3][(b+2)*3]==1
                 ||d[(a-1)*3][(b-3)*3]==1&&d[(a-1)*3][(b-2)*3]==1&&d[(a-1)*3][(b-1)*3]==1&&d[(a-1)*3][(b)*3]==1&&d[(a-1)*3][(b+1)*3]==1
                 ||d[(a-1)*3][(b-4)*3]==1&&d[(a-1)*3][(b-3)*3]==1&&d[(a-1)*3][(b-2)*3]==1&&d[(a-1)*3][(b-1)*3]==1&&d[(a-1)*3][(b)*3]==1
                 ||d[(a-1)*3][(b-5)*3]==1&&d[(a-1)*3][(b-4)*3]==1&&d[(a-1)*3][(b-3)*3]==1&&d[(a-1)*3][(b-2)*3]==1&&d[(a-1)*3][(b-1)*3]==1
                 //從左上到右下
                 ||d[(a-1)*3][(b-1)*3]==1&&d[a*3][b*3]==1&&d[(a+1)*3][(b+1)*3]==1&&d[(a+2)*3][(b+2)*3]==1&&d[(a+3)*3][(b+3)*3]==1
                 ||d[(a-2)*3][(b-2)*3]==1&&d[(a-1)*3][(b-1)*3]==1&&d[a*3][b*3]==1&&d[(a+1)*3][(b+1)*3]==1&&d[(a+2)*3][(b+2)*3]==1
                 ||d[(a-3)*3][(b-3)*3]==1&&d[(a-2)*3][(b-2)*3]==1&&d[(a-1)*3][(b-1)*3]==1&&d[a*3][b*3]==1&&d[(a+1)*3][(b+1)*3]==1
                 ||d[(a-4)*3][(b-4)*3]==1&&d[(a-3)*3][(b-3)*3]==1&&d[(a-2)*3][(b-2)*3]==1&&d[(a-1)*3][(b-1)*3]==1&&d[a*3][b*3]==1
                 ||d[(a-5)*3][(b-5)*3]==1&&d[(a-4)*3][(b-4)*3]==1&&d[(a-3)*3][(b-3)*3]==1&&d[(a-2)*3][(b-2)*3]==1&&d[(a-1)*3][(b-1)*3]==1
                 //從右上到左下
                 ||d[(a-1)*3][(b-1)*3]==1&&d[(a-2)*3][b*3]==1&&d[a-3][b+1]==1&&d[a-4][b+2]==1&&d[a-5][b+3]==1
                 ||d[a*3][(b-2)*3]==1&&d[(a-1)*3][(b-1)*3]==1&&d[(a-2)*3][b*3]==1&&d[(a-3)*3][(b+1)*3]==1&&d[(a-4)*3][(b+2)*3]==1
                 ||d[(a+1)*3][(b-3)*3]==1&&d[a*3][(b-2)*3]==1&&d[(a-1)*3][(b-1)*3]==1&&d[(a-2)*3][b*3]==1&&d[(a-3)*3][(b+1)*3]==1
                 ||d[(a+2)*3][(b-4)*3]==1&&d[(a+1)*3][(b-3)*3]==1&&d[a*3][(b-2)*3]==1&&d[(a-1)*3][(b-1)*3]==1&&d[(a-2)*3][b*3]==1
                 ||d[(a+3)*3][(b-5)*3]==1&&d[(a+2)*3][(b-4)*3]==1&&d[(a+1)*3][(b-3)*3]==1&&d[a*3][(b-2)*3]==1&&d[(a-1)*3][(b-1)*3]==1
                 //豎著
                    ||d[(a-1)*3][(b-1)*3]==1&&d[a*3][(b-1)*3]==1&&d[(a+1)*3][(b-1)*3]==1&&d[(a+2)*3][(b-1)*3]==1&&d[(a+3)*3][(b-1)*3]==1
                 ||d[(a-2)*3][(b-1)*3]==1&&d[(a-1)*3][(b-1)*3]==1&&d[a*3][(b-1)*3]==1&&d[(a+1)*3][(b-1)*3]==1&&d[(a+2)*3][(b-1)*3]==1
                 ||d[(a-3)*3][(b-1)*3]==1&&d[(a-2)*3][(b-1)*3]==1&&d[(a-1)*3][(b-1)*3]==1&&d[a*3][(b-1)*3]==1&&d[(a+1)*3][(b-1)*3]==1
                 ||d[(a-4)*3][(b-1)*3]==1&&d[(a-3)*3][(b-1)*3]==1&&d[(a-2)*3][(b-1)*3]==1&&d[(a-1)*3][(b-1)*3]==1&&d[a*3][(b-1)*3]==1
                 ||d[(a-5)*3][(b-1)*3]==1&&d[(a-4)*3][(b-1)*3]==1&&d[(a-3)*3][(b-1)*3]==1&&d[(a-2)*3][(b-1)*3]==1&&d[(a-1)*3][(b-1)*3]==1
                 )
                {
                 cout<<endl<<"玩家一獲勝"<<endl;break;
                }

                if(//橫著
                 d[(a-1)*3][(b-1)*3]==3&&d[(a-1)*3][(b)*3]==3&&d[(a-1)*3][(b+1)*3]==3&&d[(a-1)*3][(b+2)*3]==3&&d[(a-1)*3][(b+3)*3]==3
                 ||d[(a-1)*3][(b-2)*3]==3&&d[(a-1)*3][(b-1)*3]==3&&d[(a-1)*3][(b)*3]==3&&d[(a-1)*3][(b+1)*3]==3&&d[(a-1)*3][(b+2)*3]==3
                 ||d[(a-1)*3][(b-3)*3]==3&&d[(a-1)*3][(b-2)*3]==3&&d[(a-1)*3][(b-1)*3]==3&&d[(a-1)*3][(b)*3]==3&&d[(a-1)*3][(b+1)*3]==3
                 ||d[(a-1)*3][(b-4)*3]==3&&d[(a-1)*3][(b-3)*3]==3&&d[(a-1)*3][(b-2)*3]==3&&d[(a-1)*3][(b-1)*3]==3&&d[(a-1)*3][(b)*3]==3
                 ||d[(a-1)*3][(b-5)*3]==3&&d[(a-1)*3][(b-4)*3]==3&&d[(a-1)*3][(b-3)*3]==3&&d[(a-1)*3][(b-2)*3]==3&&d[(a-1)*3][(b-1)*3]==3
                 //從左上到右下
                 ||d[(a-1)*3][(b-1)*3]==3&&d[a*3][b*3]==3&&d[(a+1)*3][(b+1)*3]==3&&d[(a+2)*3][(b+2)*3]==3&&d[(a+3)*3][(b+3)*3]==3
                 ||d[(a-2)*3][(b-2)*3]==3&&d[(a-1)*3][(b-1)*3]==3&&d[a*3][b*3]==3&&d[(a+1)*3][(b+1)*3]==3&&d[(a+2)*3][(b+2)*3]==3
                 ||d[(a-3)*3][(b-3)*3]==3&&d[(a-2)*3][(b-2)*3]==3&&d[(a-1)*3][(b-1)*3]==3&&d[a*3][b*3]==3&&d[(a+1)*3][(b+1)*3]==3
                 ||d[(a-4)*3][(b-4)*3]==3&&d[(a-3)*3][(b-3)*3]==3&&d[(a-2)*3][(b-2)*3]==3&&d[(a-1)*3][(b-1)*3]==3&&d[a*3][b*3]==3
                 ||d[(a-5)*3][(b-5)*3]==3&&d[(a-4)*3][(b-4)*3]==3&&d[(a-3)*3][(b-3)*3]==3&&d[(a-2)*3][(b-2)*3]==3&&d[(a-1)*3][(b-1)*3]==3
                 //從右上到左下
                 ||d[(a-1)*3][(b-1)*3]==3&&d[(a-2)*3][b*3]==3&&d[a-3][b+1]==3&&d[a-4][b+2]==3&&d[a-5][b+3]==3
                 ||d[a*3][(b-2)*3]==3&&d[(a-1)*3][(b-1)*3]==3&&d[(a-2)*3][b*3]==3&&d[(a-3)*3][(b+1)*3]==3&&d[(a-4)*3][(b+2)*3]==3
                 ||d[(a+1)*3][(b-3)*3]==3&&d[a*3][(b-2)*3]==3&&d[(a-1)*3][(b-1)*3]==3&&d[(a-2)*3][b*3]==3&&d[(a-3)*3][(b+1)*3]==3
                 ||d[(a+2)*3][(b-4)*3]==3&&d[(a+1)*3][(b-3)*3]==3&&d[a*3][(b-2)*3]==3&&d[(a-1)*3][(b-1)*3]==3&&d[(a-2)*3][b*3]==3
                 ||d[(a+3)*3][(b-5)*3]==3&&d[(a+2)*3][(b-4)*3]==3&&d[(a+1)*3][(b-3)*3]==3&&d[a*3][(b-2)*3]==3&&d[(a-1)*3][(b-1)*3]==3
                 //豎著
                    ||d[(a-1)*3][(b-1)*3]==3&&d[a*3][(b-1)*3]==3&&d[(a+1)*3][(b-1)*3]==3&&d[(a+2)*3][(b-1)*3]==3&&d[(a+3)*3][(b-1)*3]==3
                 ||d[(a-2)*3][(b-1)*3]==3&&d[(a-1)*3][(b-1)*3]==3&&d[a*3][(b-1)*3]==3&&d[(a+1)*3][(b-1)*3]==3&&d[(a+2)*3][(b-1)*3]==3
                 ||d[(a-3)*3][(b-1)*3]==3&&d[(a-2)*3][(b-1)*3]==3&&d[(a-1)*3][(b-1)*3]==3&&d[a*3][(b-1)*3]==3&&d[(a+1)*3][(b-1)*3]==3
                 ||d[(a-4)*3][(b-1)*3]==3&&d[(a-3)*3][(b-1)*3]==3&&d[(a-2)*3][(b-1)*3]==3&&d[(a-1)*3][(b-1)*3]==3&&d[a*3][(b-1)*3]==3
                 ||d[(a-5)*3][(b-1)*3]==3&&d[(a-4)*3][(b-1)*3]==3&&d[(a-3)*3][(b-1)*3]==3&&d[(a-2)*3][(b-1)*3]==3&&d[(a-1)*3][(b-1)*3]==3
                 )
                {
               cout<<endl<<"玩家二獲勝"<<endl;break;
                }
             }
             return 0;
            }
            int main()
            {
             char a;
             wz();
             hs();
             while(1)
              {
              cout<<"按P重新開始:";
              cin>>a;
              if(a=='p')
               hs();
              else
               break;
              }
             return 0; 
            }




            人機對戰暫時沒想出來,有知道的希望指教一下!!感激----

            posted @ 2012-04-12 23:48 迎風而立 閱讀(1558) | 評論 (5)編輯 收藏

            2012年4月8日

            關于移位運算符和取反運算符的一點感悟

            今天在學習移位運算符和取反運算符的時候,發現一些問題!現在呢在這里說一下自己的感悟!

            先看下面一道 取反和移位相結合的問題


            #include<stdio.h>
            int main()
            {
             char a=0x11;
             char b;
             b=~a<<2;
             printf("%d\n",b);
             b=~(a<<2);
             printf("%d\n",b);
             b=~a>>2;
             printf("%d\n",b);
             b=~(a>>2);
             printf("%d\n",b);
             return 0;
            }

             

            輸出結果是:

            -72
            -69
            -5
            -5

             

            剛開始在想為什么相同的操作(只是移位方向不同),為什么上面兩個結果不一樣,而下面兩個結果卻是一樣的呢。有些人在疑問是不是因為下面兩個表達式都是先移位后取反的呢?我可以肯定不是這樣的,但是不能解釋這個結果。這個問題我糾結了半天!  不過對下面的知識了解之后便豁然開朗了。

            移位運算符分為左移運算符和右移運算符。
            當對一個數執行左移運算的時候,右邊的空位是用0補齊。
            而當對一個數執行右移運算的時候,左邊的空位是用符號位補齊的(這是我之前沒注意的地方,慚愧)。

             

            解體步驟如下:


            a=0x11=0001 0001

            ~a=1110 1110
            a<<2=0100 0100
            a>>2=0000 0100


            ~a<<2=1011 1000 
            現在 1011 1000是補碼,轉化成原碼之后是
            1100 1000=-72  -72是十進制

            ~(a<<2)=0100 0100
            轉化為原碼之后是 1100 0101=-69


            ~a>>2=1111 1011(注意現在是用1補齊的,因為~a的符號位是1)
            轉化為原碼之后是  1000 0101=-5


            ~(a>>2)=1111 1011
            轉化為原碼之后是  1000 0101=-5


            明白之后心情很好,所以在這里分享一下。呵呵

            posted @ 2012-04-08 21:29 迎風而立 閱讀(1695) | 評論 (2)編輯 收藏

            僅列出標題  
            <2025年5月>
            27282930123
            45678910
            11121314151617
            18192021222324
            25262728293031
            1234567

            導航

            統計

            常用鏈接

            留言簿

            隨筆檔案

            搜索

            最新評論

            閱讀排行榜

            評論排行榜

            国产巨作麻豆欧美亚洲综合久久| 欧洲精品久久久av无码电影 | 亚洲中文字幕无码一久久区| 精品国产青草久久久久福利| 久久天天躁狠狠躁夜夜不卡| 国色天香久久久久久久小说| 91精品国产91久久久久福利| 久久精品中文字幕第23页| 欧美精品福利视频一区二区三区久久久精品 | 久久久久亚洲AV无码专区首JN| 久久久无码一区二区三区| 成人国内精品久久久久影院VR| 久久无码AV一区二区三区| 亚洲国产精品久久久久网站| 精品久久久无码人妻中文字幕 | 精品国产婷婷久久久| 亚洲av伊人久久综合密臀性色| 国产精品天天影视久久综合网| 亚洲精品99久久久久中文字幕| 97久久超碰成人精品网站| 久久频这里精品99香蕉久| 久久精品国产精品青草| 7777精品久久久大香线蕉| 久久久噜噜噜久久中文字幕色伊伊| 99国产欧美精品久久久蜜芽| 2021最新久久久视精品爱| 欧美日韩精品久久久久| 爱做久久久久久| 久久精品视频网| 久久精品一区二区国产| 久久久久久久久久久久中文字幕 | 久久er热视频在这里精品| 一本色道久久综合亚洲精品| 2021国产精品久久精品| 香港aa三级久久三级老师2021国产三级精品三级在 | 狠狠精品久久久无码中文字幕| 一本久久免费视频| 伊人久久国产免费观看视频| 久久91精品综合国产首页| 国产精品一区二区久久精品无码 | 国产日韩久久久精品影院首页|