亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > C > 正文

c語言:金幣陣列的問題

2020-01-26 16:21:16
字體:
來源:轉載
供稿:網友

  有m*n(m <=100,n <=100)個金幣在桌面上排成一個m行n 列的金幣陣列。每一枚金幣或正面朝上或背面朝上。用數字表示金幣狀態,0表示金幣正面朝上,1 表示背面朝上。

  金幣陣列游戲的規則是: (1)每次可將任一行金幣翻過來放在原來的位置上;

  (2)每次可任選2 列,交換這2 列金幣的位置。

   編程任務:給定金幣陣列的初始狀態和目標狀態,編程計算按金幣游戲規則,將金幣陣列從初始狀態變換到目標狀態所需的最少變換次數。

Input

  輸入數據有多組數據。第1行有1 個正整數k,表示有k 組數據。每組數據的第1 行有2 個正整數m 和n。以下的m行是金幣陣列的初始狀態,每行有n 個數字表示該行金幣的狀態,0 表示金幣正面朝上,1 表示背面朝上。接著的m行是金幣陣列的目標狀態。

Output

  將計算出的最少變換次數按照輸入數據的次序輸出。相應數據無解時輸出-1。

代碼是別人的,感覺寫的很好。寫這個博客,主要是想要重溫一下思路。

枚舉1~m中,每一列為第一列的情況,

//從1~n行,找出不滿足的行,進行一次行變換

//若是所枚舉的這一列可以成功根據規則轉換成目標矩陣,則,此時的矩陣與原矩陣的差別只會在列序上

此時,從i=2 列(第二列)開始與目標矩陣的第i列進行比較,

若不同,尋找本矩陣中第j列(就= i+1~m)是否有與目標矩陣的第i列相同的,若有,且 本矩陣第j列!= 目標矩陣第j列,則,進行一次列變換

//若是找不到符合條件的列,則所枚舉的這一列為第一列是不可能按所給規則變換到目標矩陣的

復制代碼 代碼如下:

#include<stdio.h>

 const int inf = 99999;
 const int N = 101;

 int a[N][N],b[N][N],temp[N][N]; //a存儲初始矩陣,b為目標狀態矩陣
 int n,m;
 int need;//需要變換次數

 void ChangeL(int x,int y)//變換列
 {
     if(x==y)return;
     int i;
     for(i=1;i<=n;i++)
     {
         int tt=temp[i][y];
         temp[i][y]=temp[i][x];
         temp[i][x]=tt;
     }
     need++;
 }

 void ChangeH(int x)//變換行
 {
     int i;
     for(i=1;i<=m;i++)
     {
         temp[x][i]^=1;
     }
 }

 bool Same(int x,int y) //判斷列是否滿足條件
 {
     int i;
     for(i=1;i<=n;i++)
         if(b[i][x]!=temp[i][y])return false;
     return true;
 }

 int main()
 {
     int tests;
     scanf("%d",&tests); //數據組數

     while(tests--)
     {
         scanf("%d%d",&n,&m); //n行,m列
         int i,j;
         for(i=1;i<=n;i++)
             for(j=1;j<=m;j++)
             {
                 scanf("%d",&a[i][j]);
             }

             for(i=1;i<=n;i++)
                 for(j=1;j<=m;j++)
                     scanf("%d",&b[i][j]);

             int k;
             int ans=inf; //ans存儲最終答案,初始值為無窮大

 
             for(k=1;k<=m;k++)//枚舉各列為第一列
             {
                 for(i=1;i<=n;i++)
                     for(j=1;j<=m;j++)
                         temp[i][j]=a[i][j];
                 need=0;
                 ChangeL(1,k);

 
                 //不滿足的行,進行一次變換
                 for(i=1;i<=n;i++)
                 {
                     if(temp[i][1]!=b[i][1])//該行不滿足條件
                     {
                         ChangeH(i);//變換行
                         need++;
                     }
                 }

                 bool find;
                 for(i=1;i<=m;i++)//檢查每列是否滿足條件
                 {
                     find=false;
                     if(Same(i,i))
                     {
                         find=true;
                         continue;
                     }
                     for(j=i+1;j<=m;j++)//尋找temp中與b的i列相同的列
                     {
                         if(Same(i,j))//temp 的 j列于b的i列相同
                         {
                             if(Same(j,j))continue;//temp的j列與b的j列相同
                             ChangeL(i,j);//交換temp的i,j列
                             find=true;
                             break;
                         }
                     }
                     if(find==false)//找不到該列對應列
                     {
                         break;
                     }
                 }

                 if(find==true&&need<ans)
                     ans=need;
             }

             if(ans<inf)
                 printf("%d/n",ans);
             else
                 printf("-1/n");
     }
     return 0;
 }

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表

圖片精選

亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国产精品高潮在线| 欧美一区二区影院| 精品久久香蕉国产线看观看gif| 亚洲女成人图区| 成人精品一区二区三区电影免费| 亚洲美女久久久| 欧美日韩午夜激情| 日韩欧美精品在线观看| 欧美一区三区三区高中清蜜桃| 91精品国产91| 欧美日韩在线另类| 久久久久久999| 成人性生交大片免费看视频直播| 欧美视频在线免费看| 欧美一级大片在线观看| 一本大道久久加勒比香蕉| 精品久久久久久中文字幕| 久久99久久亚洲国产| 久久国产精品视频| 激情久久av一区av二区av三区| 成人在线播放av| 亚洲mm色国产网站| 久久在线免费观看视频| 精品毛片三在线观看| 在线观看精品国产视频| 久久久精品免费视频| 日韩亚洲在线观看| 亚洲国产成人91精品| 亚洲国产女人aaa毛片在线| 亚洲精品天天看| 久久免费国产精品1| 日本国产欧美一区二区三区| 久久精品视频在线| 98精品国产高清在线xxxx天堂| 国产精品视频精品视频| 国产精品久久久久7777婷婷| 韩国精品美女www爽爽爽视频| 久久久久这里只有精品| 亚洲精品在线91| 国内外成人免费激情在线视频| 亚洲成人av在线| 中文日韩在线视频| 国产精品av免费在线观看| 欧美激情一级精品国产| 亚洲aa在线观看| www.久久久久| 91久久久亚洲精品| 日韩成人在线网站| 亚洲日韩中文字幕| 国产精品久久久久aaaa九色| 日本精品免费观看| 国产精品亚洲аv天堂网| 成人黄色激情网| 激情亚洲一区二区三区四区| 欧美在线视频一二三| 日韩国产中文字幕| 久久久精品2019中文字幕神马| 亚洲一级一级97网| 91网站免费观看| 亚洲码在线观看| 亚洲午夜激情免费视频| 2019国产精品自在线拍国产不卡| 亚洲欧美国产另类| 中文字幕亚洲在线| 国产精品入口日韩视频大尺度| 久久激情视频久久| 欧美日韩另类字幕中文| 国产玖玖精品视频| 久久久久国色av免费观看性色| 成人激情免费在线| 日韩成人免费视频| 欧美做受高潮1| 国产一区二区欧美日韩| 欧日韩在线观看| 久久99亚洲热视| 日韩在线欧美在线国产在线| 在线日韩av观看| 美日韩精品免费观看视频| 国产激情视频一区| 欧美性感美女h网站在线观看免费| 91久久国产精品| 亚洲精品日韩激情在线电影| 亚洲综合社区网| 日韩在线观看网址| 欧美专区国产专区| 欧美精品免费在线| 久久久精品久久久| 91sao在线观看国产| 一个人看的www久久| 久久久精品久久| 亚洲天堂一区二区三区| 成人做爰www免费看视频网站| 91精品国产亚洲| 136fldh精品导航福利| 欧美性xxxxxxx| 青青草一区二区| 久久激情视频免费观看| 国产精品日日做人人爱| 欧美日韩亚洲高清| 国产精品女主播| 久久久久久久久久久网站| 亚洲色图美腿丝袜| 91亚洲国产成人久久精品网站| 日韩在线观看免费| 日韩美女在线观看一区| 日本aⅴ大伊香蕉精品视频| 黑人巨大精品欧美一区二区免费| 亚洲社区在线观看| 88国产精品欧美一区二区三区| 欧美性色19p| 欧美性在线视频| 亚洲图片在区色| 国产日韩欧美自拍| 欧美成人中文字幕在线| 久久精品2019中文字幕| 亚洲最大在线视频| 亚洲欧美日韩精品久久亚洲区| 91成品人片a无限观看| 91av在线影院| 亚洲精品视频网上网址在线观看| 久久五月天色综合| 国产日韩亚洲欧美| 亚洲欧美三级伦理| 国语自产精品视频在线看抢先版图片| 一本一本久久a久久精品牛牛影视| 国产又爽又黄的激情精品视频| 亚洲美女中文字幕| 国产精品福利观看| 日本高清+成人网在线观看| 中文字幕欧美亚洲| 亚洲v日韩v综合v精品v| 国产精品久久久久久搜索| 亚洲国产成人精品久久| 欧美极品少妇与黑人| 成人午夜在线影院| 日本久久中文字幕| 中文字幕av一区中文字幕天堂| 日韩综合视频在线观看| 欧美成人在线影院| 精品国产乱码久久久久酒店| 亚洲欧美日韩中文在线制服| 5252色成人免费视频| 国产精品久久久久久久久久久久久久| 一区二区三区 在线观看视| 欧美www在线| 久久久久久久亚洲精品| 亚洲jizzjizz日本少妇| 高跟丝袜欧美一区| 精品视频—区二区三区免费| 欧美成人自拍视频| 亚洲精品久久久久久久久久久久| www.欧美免费| 亚洲精品久久久久久久久久久| 亚洲女人天堂成人av在线| 狠狠躁天天躁日日躁欧美| 欧美专区在线观看| 国产精品成人久久久久| 欧美激情免费看| 国产亚洲精品久久久久久牛牛| 91地址最新发布| 欧美性感美女h网站在线观看免费| 永久免费毛片在线播放不卡| 日韩欧美aⅴ综合网站发布| 欧美黄色三级网站|