欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

c語言:金幣陣列的問題

 更新時間:2013年03月06日 09:51:14   作者:  
本文介紹了關于c語言:金幣陣列的問題,需要的朋友可以參考一下

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

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

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

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

Input

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

Output

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

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

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

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

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

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

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

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

復制代碼 代碼如下:

#include<stdio.h>

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

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

 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); //數(shù)據(jù)組數(shù)

     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;
 }

相關文章

  • C語言小游戲之簡易版三子棋(棋盤可自由擴展)

    C語言小游戲之簡易版三子棋(棋盤可自由擴展)

    這篇文章主要為大家詳細介紹了C語言實現(xiàn)三子棋游戲,還可以自由擴展棋盤大小,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-11-11
  • C語言編程中建立和解除內(nèi)存映射的方法

    C語言編程中建立和解除內(nèi)存映射的方法

    這篇文章主要介紹了C語言編程中建立和解除內(nèi)存映射的方法,分別為mmap()函數(shù)和munmap()函數(shù)的使用,需要的朋友可以參考下
    2015-08-08
  • C語言詳細分析講解關鍵字const與volatile的用法

    C語言詳細分析講解關鍵字const與volatile的用法

    在C語言中,我們經(jīng)常會見到const和volatile這兩個關鍵字,那么我們今天就來介紹下這兩個關鍵字,提起?const?關鍵字,我們可能首先想到的是經(jīng)過它修飾的變量便是常量了。其實我們這種想法是錯誤的,其實?const?修飾的變量是只讀的,其本質(zhì)還是變量
    2022-04-04
  • C語言實現(xiàn)簡易網(wǎng)絡聊天室

    C語言實現(xiàn)簡易網(wǎng)絡聊天室

    這篇文章主要為大家詳細介紹了C語言實現(xiàn)簡易網(wǎng)絡聊天室,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-06-06
  • MFC對話框中添加狀態(tài)欄的方法

    MFC對話框中添加狀態(tài)欄的方法

    這篇文章主要介紹了MFC對話框中添加狀態(tài)欄的方法,實例分析了MFC對話框添加狀態(tài)欄所涉及的相關成員變量與事件實現(xiàn)技巧,需要的朋友可以參考下
    2015-07-07
  • C++實現(xiàn)LeetCode(163.缺失區(qū)間)

    C++實現(xiàn)LeetCode(163.缺失區(qū)間)

    這篇文章主要介紹了C++實現(xiàn)LeetCode(163.缺失區(qū)間),本篇文章通過簡要的案例,講解了該項技術的了解與使用,以下就是詳細內(nèi)容,需要的朋友可以參考下
    2021-07-07
  • pthread_cond_wait() 用法深入分析

    pthread_cond_wait() 用法深入分析

    以下是對pthread_cond_wait的用法進行了詳細的分析介紹,需要的朋友可以過來參考下
    2013-07-07
  • 使用C語言實現(xiàn)掃雷小游戲

    使用C語言實現(xiàn)掃雷小游戲

    這篇文章主要為大家詳細介紹了使用C語言實現(xiàn)掃雷小游戲,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-05-05
  • c語言尾隊列tailq使用示例分享

    c語言尾隊列tailq使用示例分享

    這篇文章主要介紹了c語言尾隊列tailq使用示例,大家參考使用吧
    2014-01-01
  • C++讀寫ini配置文件實現(xiàn)過程詳解

    C++讀寫ini配置文件實現(xiàn)過程詳解

    這篇文章主要介紹了C++讀寫ini配置文件實現(xiàn)過程詳解,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2020-07-07

最新評論