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
- Flip Game
- Flip Game
- Flip Game
- Flip Game
- Flip Game
- Flip Game
- flip game
- Flip Game
- Flip Game
- FLIP GAME
- Flip Game
- Flip Game
- Flip Game
- Flip Game
- Flip Game
- Flip Game
- Flip Game
- Flip Game
- 排序算法
- 仿手机QQ聊天列表滑动菜单删除和手势滑动返回的两种方式
- ServiceMix(一)
- mongodb的高级操作(聚合框架)
- asm在某个节点上没有执行
- Flip Game
- 指向同一个字符串的指针和数组的地址区别-包含const
- C# listbox 用法
- 手把手教你ARC——iOS/Mac开发ARC入门和使用
- Two Sum
- Linux头文件和库文件添加环境变量与GCC编译器添加INCLUDE与LIB环境变量
- SERVER Error filter start 的解决方案汇总
- 皮尔森相关系数
- iOS开发何如在调试的时候轻松找到程序在哪里崩溃