Consider the following position as an example: bwbw wwww bbwb bwwb Here "b" denotes pieces lying their black side up and "w" denotes pieces lying their white side up. If we choose to flip the 1st piece from the 3rd row (this choice is shown at the picture), then the field will become: bwbw bwww wwwb wwwb The goal of the game is to flip either all pieces white side up or all pieces black side up. You are to write a PRogram that will search for the minimum number of rounds needed to achieve this goal. InputThe input consists of 4 lines with 4 characters "w" or "b" each that denote game field position.OutputWrite to the output file a single integer number - the minimum number of rounds needed to achieve the goal of the game from the given position. If the goal is initially achieved, then write 0. If it's impossible to achieve the goal, then write the Word "Impossible" (without quotes).Sample InputbwwbbbwbbwwbbwwwSample Output4解題報告
不要想太復(fù)雜就好,要明確如果有答案,那么答案小于等于8#include<stdio.h>#include<string.h>bool map[6][6];int ox[]={0,0,0,1,-1};int oy[]={0,1,-1,0,0};int best;bool check(){ //end check for(int j=1;j<=4;j++) for(int k=1;k<=4;k++) if(map[1][1]!=map[j][k]) return false; return true;}void op(int X,int Y){ for(int i=0;i<5;i++){ int x=X+ox[i]; int y=Y+oy[i]; map[x][y]=!map[x][y]; }}void dfs(int t,int cnt){ if(check()){ if(cnt<best) best=cnt; return ; } if(cnt>best||t>16) return ; int X=t%4+1; int Y=t/4+1; //剪枝 加上該條件 78ms立馬變0ms if(Y>1&&X>1&&map[X-1][Y-1]!=map[1][1]) return ; dfs(t+1,cnt); op(X,Y); dfs(t+1,cnt+1); op(X,Y);}int main(){ char str[5]; for(int i=1;i<=4;i++){ scanf("%s",str); for(int j=1;j<=4;j++) map[i][j]=str[j-1]=='b'; } best=9; dfs(0,0); if(best<9) printf("%d/n",best); else puts("Impossible"); return 0;}
新聞熱點
疑難解答