C言語の課題「4×4のマス目に0~15の数字を一つずついれていき、タテかヨコの列に1が4つ並んだら勝利」というプログラミングを作成しました。
ここでいう1が4つ並ぶとは、0~15をそれぞれ2進数で表し、そのどれかの位に1が4つそろうという意味です。(例えば、2、6、10、11が並べば、2の1乗の位に1がそろうので、勝利)
下記のプログラミングをさらに改良して、できるだけ短く簡略化したいのですが、どこをなおしたらいいかいい考えが思いつきません。
何か改善点があればご指摘お願いします。
#include <stdio.h> #include <stdlib.h> #include <time.h> int ban[4][4]={{16,16,16,16},{16,16,16,16},{16,16,16,16},{16,16,16,16}}; void mks(int *p) { int i,a,b,tmp; for(i=0;i<100;i++) { a=rand()%16; b=rand()%16; tmp=*(p+a); *(p+a)=*(p+b); *(p+b)=tmp; } } int disp() { int i,j,ret=0; for(i=0;i<4;i++) { if(ban[i][0]&ban[i][1]&ban[i][2]&ban[i][3]&0x0f) { ban[i][0]+=32; ban[i][1]+=32; ban[i][2]+=32; ban[i][3]+=32; ret=1; } if(ban[0][i]&ban[1][i]&ban[2][i]&ban[3][i]&0x0f) { ban[0][i]+=32; ban[1][i]+=32; ban[2][i]+=32; ban[3][i]+=32; ret=1; } } for(i=0;i<4;i++) { for(j=0;j<4;j++) { if(ban[i][j]==16) printf("[**]"); else if(ban[i][j]>=32)printf("<%2d>",ban[i][j]&0x0f); else printf("[%2d]",ban[i][j]&0x0f); } printf("\n"); } printf("\n"); return ret; } int main() { int data_a[16]={0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15}; int data_b[16]={0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15}; int win=0; int kai=0; srand(time(NULL)); mks(data_a); mks(data_b); do { ban[data_b[kai]/4][data_b[kai]%4]=data_a[kai]; printf((kai%2)?"B is %d:%d =%d\n":"A is %d:%d =%d\n",data_b[kai]/4,data_b[kai]%4,data_a[kai]); if(disp()) { printf((kai%2)?"B Win\n":"A Win\n"); break; } } while(kai++<15); if(kai>15) printf("Drow"); return 0; }
回答2件
あなたの回答
tips
プレビュー