Flip Game

这段代码还有问题,暂时记录下来,有时间再做修改。
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;
}

你可能感兴趣的:(poj)