Flip Game

来源:互联网 发布:vs opencv python 编辑:程序博客网 时间:2024/05/18 09:18

这段代码还有问题,暂时记录下来,有时间再做修改。
http://poj.org/problem?id=1753

#include<stdio.h>#include<stdlib.h>//注意int* arr不是int *arr//int is_all_black_or_white(int* arr ,int n){   int k;   for (k=0;k<n-1;k++){       if (arr[k]!=arr[k+1]){          return 0;          break;       }   }   return 1;}void change_color(int* new_arr ,int j){   int x,y;   x=j/4;   y=j%4;   new_arr[j]=!(new_arr[j]);   //注意!(new_arr[i])写括号   //if语句后如果只有一句语句可以不写{}   if(y>0){      new_arr[j-1]=!(new_arr[j-1]);   }   if(y<3){      new_arr[j+1]=!(new_arr[j+1]);   }   if(x>0){      new_arr[j-4]=!(new_arr[j-4]);   }   if(x<3){      new_arr[j+4]=!(new_arr[j+4]);   }}void combine(int len,int* arry,,int* result,int count ,int Num, int* last){  int i=0;  for(i=len;i>=count;i--){      result[count-1]=i-1;      if(count>1)        combine(i--,arry,result,count-1,Num,last);        //注意调用函数时不需要定义变量类型    elst{       int j;       //在这里生成arry的副本       int* arr1=(int*)malloc(sizeof(int)*16);       for(j=len-1;j>=0;j--)          arr1[j]=arry[j];       //注意应该是j=Num-1不是j=Num,因为result从0开始       for(j=Num-1;j>=0;j--)          change(arr1,result[j])       if (is_all_black_or_white(arr1 ,16)){          last=Num;//注意last前面需要加*,把last的值传走          free(arr1);          break;       }       free(arr1);    }  }   }int main(){  int m,n,line,raw,count;  line=4;  raw=4;  count=0;  int len=16;  char color;  int arra[16];  for(m=line;m>0;m--) {    for(n=raw;n>0;n--){      scanf("%c",&color)      if(color=='b'){         arra[count++]=0;//count在这里的运用非常巧妙,      }      if(color=='w'){         arra[count++]=1;      }    }  }  if (is_all_black_or_white(arra ,16)){     print("%d\n",0);     //free(arr);//该语句可以放到最后一起free,可以少写几句  }  else{     //生成arra的副本,因为CNK之后原数组被改变,CNK+1就会判断不正确。     int* arr=(int* )malloc(sizeof(int)*16);     int i;     for(i=0;i<16;i++)        arr[i]=arra[i];     int j;     int last=0;     for(j=1;j<=len;j++){       int* result=(int* )malloc(sizeof(int)*j);       combine(16,arr,result,j,j,&last);//last要传送回来所以要用&符号。       if (is_all_black_or_white(arr ,16)==1){             print("%d\n",last);             break;       }         for(i=0;i<16;i++)          arr[i]=arra[i];       free(result);//马上要进行下一轮的CNK+1了     }     free(arr);//判断结束了     if(j==17 )        print ("Impossiple\n"); } return 0;}
0 0