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

            導航

            統計

            常用鏈接

            留言簿

            隨筆檔案

            搜索

            最新評論

            閱讀排行榜

            評論排行榜

            国产精品综合久久第一页| 亚洲中文精品久久久久久不卡| 久久婷婷人人澡人人| 人妻精品久久久久中文字幕69| 精品国产青草久久久久福利| 亚洲成色www久久网站夜月 | 欧美成a人片免费看久久| 久久精品国产久精国产思思| 亚洲一级Av无码毛片久久精品| 人人狠狠综合久久亚洲88| 日产精品久久久久久久性色 | 99久久国产综合精品成人影院| 伊人久久精品无码av一区| 久久久精品国产Sm最大网站| 国内精品久久久久久久97牛牛| 一级做a爰片久久毛片毛片| 91精品国产综合久久香蕉| 久久人爽人人爽人人片AV| 久久这里只有精品首页| 亚洲国产精品成人AV无码久久综合影院| 免费精品99久久国产综合精品| 粉嫩小泬无遮挡久久久久久| 亚洲AV乱码久久精品蜜桃| 久久香综合精品久久伊人| 亚洲日韩欧美一区久久久久我 | 嫩草影院久久99| 精品久久香蕉国产线看观看亚洲 | 亚洲综合久久夜AV | 亚洲v国产v天堂a无码久久| 久久精品无码一区二区三区日韩| 99久久国产综合精品五月天喷水| 香蕉久久一区二区不卡无毒影院| 久久av无码专区亚洲av桃花岛| 人妻无码αv中文字幕久久琪琪布 人妻无码久久一区二区三区免费 人妻无码中文久久久久专区 | 久久男人AV资源网站| 久久精品一区二区三区中文字幕 | 亚洲а∨天堂久久精品9966| 久久亚洲AV永久无码精品| 久久久精品波多野结衣| 欧美一级久久久久久久大| 综合久久精品色|