C语言代码实现简单2048游戏
最近玩2048上瘾,于是尝试用C++写了一个2048小游戏
操作方法很简单,通过wasd控制方块的方向,数据的上限为65536
代码如下
#include#include #include voidcolor(shortx) { if(x>=0&&x<=15) SetConsoleTextAttribute(GetStdHandle(STD_OUTPUT_HANDLE),x); else SetConsoleTextAttribute(GetStdHandle(STD_OUTPUT_HANDLE),7); } usingnamespacestd; intqp[4][4]={0}; longlongintgread=0; intpd() { inti,j; for(i=0;i<4;i++) { for(j=0;j<4;j++) { if(qp[i][j]==0) { return0; } if(i==0&&j==0) { if(qp[i][j]==qp[i+1][j]||qp[i][j]==qp[i][j+1]) { return0; } } elseif(i==0&&j==3) { if(qp[i][j]==qp[i+1][j]||qp[i][j]==qp[i][j-1]) { return0; } } elseif(i==0) { if(qp[i][j]==qp[i+1][j]||qp[i][j]==qp[i][j+1]||qp[i][j]==qp[i][j-1]) { return0; } } elseif(i==3&&j==0) { if(qp[i][j]==qp[i][j+1]||qp[i][j]==qp[i-1][j]) { return0; } } elseif(j==0) { if(qp[i][j]==qp[i+1][j]||qp[i][j]==qp[i-1][j]||qp[i][j]==qp[i][j+1]) { return0; } } elseif(i==3&&j==3) { if(qp[i][j]==qp[i-1][j]||qp[i][j]==qp[i][j-1]) { return0; } } elseif(i==3) { if(qp[i][j]==qp[i-1][j]||qp[i][j]==qp[i][j-1]||qp[i][j]==qp[i][j+1]) { return0; } } elseif(j==3) { if(qp[i][j]==qp[i-1][j]||qp[i][j]==qp[i][j-1]||qp[i][j]==qp[i+1][j]) { return0; } } } } return1; } intsjs() { intnum=rand()%100+1; if(num<=5) { return4; } else { return2; } } intsc() { for(;;) { intn=rand()%4; intm=rand()%4; if(qp[n][m]==0) { qp[n][m]=sjs(); return0; } } } voiddy(intn) { if(n==0) { cout<<""; } elseif(n==2) { color(7); cout<<""< =0;j--) { if(qp[i][j]!=0) { intk=j; while(qp[i][k+1]==0&&k!=3) { k++; } qp[i][k]=qp[i][j]; if(k!=j) { qp[i][j]=0; g=1; } } } if(qp[i][3]==qp[i][2]&&qp[i][3]!=0) { qp[i][3]=qp[i][3]*2; gread+=qp[i][3]; qp[i][2]=qp[i][1]; qp[i][1]=qp[i][0]; qp[i][0]=0; g=1; } if(qp[i][2]==qp[i][1]&&qp[i][2]!=0) { qp[i][2]=qp[i][2]*2; gread+=qp[i][2]; qp[i][1]=qp[i][0]; qp[i][0]=0; g=1; } if(qp[i][1]==qp[i][0]&&qp[i][1]!=0) { qp[i][1]=qp[i][1]*2; gread+=qp[i][1]; qp[i][0]=0; g=1; } } if(g==0) { cout<<"换个方向试试~"< =0;j--) { if(qp[j][i]!=0) { intk=j; while(qp[k+1][i]==0&&k!=3) { k++; } qp[k][i]=qp[j][i]; if(k!=j) { qp[j][i]=0; g=1; } } } if(qp[3][i]==qp[2][i]&&qp[3][i]!=0) { qp[3][i]=qp[3][i]*2; gread+=qp[3][i]; qp[2][i]=qp[1][i]; qp[1][i]=qp[0][i]; qp[0][i]=0; g=1; } if(qp[2][i]==qp[1][i]&&qp[2][i]!=0) { qp[2][i]=qp[2][i]*2; gread+=qp[2][i]; qp[1][i]=qp[0][i]; qp[0][i]=0; g=1; } if(qp[1][i]==qp[0][i]&&qp[1][i]!=0) { qp[1][i]=qp[1][i]*2; gread+=qp[1][i]; qp[0][i]=0; g=1; } } if(g==0) { cout<<"换个方向试试~"< >s; if(strcmp(s,"quit")==0) { break; } } return0; }
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持毛票票。
声明:本文内容来源于网络,版权归原作者所有,内容由互联网用户自发贡献自行上传,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任。如果您发现有涉嫌版权的内容,欢迎发送邮件至:czq8825#qq.com(发邮件时,请将#更换为@)进行举报,并提供相关证据,一经查实,本站将立刻删除涉嫌侵权内容。