2048C++实现代码

来源:本站
导读:目前正在解读《2048C++实现代码》的相关信息,《2048C++实现代码》是由用户自行发布的知识型内容!下面请观看由(电工技术网 - www.9ddd.net)用户发布《2048C++实现代码》的详细说明。
简介:#include
#include
#include
#include
#include
#include

/*By Reason*/#include#include#include#include#include#include //为了读取方向键#includeusing namespace std;//srand( (unsigned)time( NULL ) ); //随机数种子 不能用在这里int pane[4][4]; //棋盘int N=1; //2的n次方void showpane() //显示棋盘{ cout<<setw(46)<<"X2048 by Reason"<<endl; cout<<setw(50)<<" |-----------------------|"<<endl; for(int i=0;i<=3;i++) { cout<<setw(24)<<""; for(int j=0;j<=3;j++) { //SetConsoleTextAttribute(GetStdHandle(STD_OUTPUT_HANDLE),FOREGROUND_RED); if(pane[i][j]==0) cout<<setw(2)<<"|"<<setw(4)<<" "; else cout<<setw(2)<<"|"<<setw(4)<<pane[i][j]; if(j==3) { cout<<setw(2)<<"|"<<endl; cout<<setw(50)<<" |-----------------------|"<<endl; } } }}void newgame() //开始游戏{ N=1; for(int i=0;i<=3;i++) //初始化棋盘 for(int j=0;j<=3;j++) pane[i][j]=0; srand( (unsigned)time( NULL ) ); int m=rand()%4; int n=rand()%4; int p=rand()%4; int q=rand()%4; pane[m][n]=pane[p][q]=2; showpane();}int if2n(int x) //判断x是否是2的n次方{ int flag=0; for(int n=1;n<=11;n++) { if(x==pow(2,n)) { flag=1; if(n>N) N=n; return flag; } } return flag;}int upmove() //上移{ int flag=0; for(int j=0;j<=3;j++) for(int i=0;i<3;i++) { if(if2n(pane[i][j]+pane[i+1][j])==1) { pane[i][j]=pane[i][j]+pane[i+1][j]; pane[i+1][j]=0; flag=1; } } return flag;}int downmove() //下移{ int flag=0; for(int j=0;j<=3;j++) for(int i=3;i>0;i--) { if(if2n(pane[i][j]+pane[i-1][j])==1) { pane[i][j]=pane[i][j]+pane[i-1][j]; pane[i-1][j]=0; flag=1; } } return flag;}int leftmove() //左移{ int flag=0; for(int i=0;i<=3;i++) for(int j=0;j<3;j++) { if(if2n(pane[i][j]+pane[i][j+1])==1) { pane[i][j]=pane[i][j]+pane[i][j+1]; pane[i][j+1]=0; flag=1; } } return flag;}int rightmove() //右移{ int flag=0; for(int i=0;i<=3;i++) for(int j=3;j>0;j--) { if(if2n(pane[i][j]+pane[i][j-1])==1) { pane[i][j]=pane[i][j]+pane[i][j-1]; pane[i][j-1]=0; flag=1; } } return flag;}int testup() //能否上移测试{ int flag=0; for(int j=0;j<=3;j++) for(int i=0;i<3;i++) { if((if2n(pane[i][j]+pane[i+1][j])==1)&&pane[i+1][j]) { flag=1; } } return flag;}int testdown() //测试能否下移{ int flag=0; for(int j=0;j<=3;j++) for(int i=3;i>0;i--) { if((if2n(pane[i][j]+pane[i-1][j])==1)&&pane[i-1][j]) { flag=1; } } return flag;}int testleft() //测试能否左移{ int flag=0; for(int i=0;i<=3;i++) for(int j=0;j<3;j++) { if((if2n(pane[i][j]+pane[i][j+1])==1)&&pane[i][j+1]) { flag=1; } } return flag;}int testright() //测试能否右移{ int flag=0; for(int i=0;i<=3;i++) for(int j=3;j>0;j--) { if((if2n(pane[i][j]+pane[i][j-1])==1)&&pane[i][j-1]) { flag=1; } } return flag;}int panemax() //棋盘最大数{ int max=pane[0][0]; for(int i=0;i<=3;i++) for(int j=0;j<=3;j++) if(pane[i][j]>max) max=pane[i][j]; return max;}int ifwin() //判断是否胜利{ int flag=0; if(panemax()==2048) { cout<<setw(45)<<"You Win!"<<endl; flag=1; } return flag;}int ifGameOver() //判断是否游戏结束{ int flag=0; if(testup()+ testdown() + testleft() + testright() == 0) { cout<<setw(43)<<"Game Over!"<<endl; flag=1; } return flag;}void addnewnumberup() //上移后添加新数{ srand( (unsigned)time( NULL ) ); int n; if(N==1) n=1; else n=(rand()%(N)+1); int newnumber=pow(2,n); for(int i=3;i>=0;i--) for(int j=0;j<=3;j++) if(pane[i][j]==0) { pane[i][j]=newnumber; return; }}void addnewnumberdown() //下移后添加新数{ srand( (unsigned)time( NULL ) ); int n; if(N==1) n=1; else n=(rand()%(N)+1); int newnumber=pow(2,n); for(int i=0;i<=3;i++) for(int j=0;j<=3;j++) if(pane[i][j]==0) { pane[i][j]=newnumber; return; }}void addnewnumberleft() //左移后添加新数{ srand( (unsigned)time( NULL ) ); int n; if(N==1) n=1; else n=(rand()%(N)+1); int newnumber=pow(2,n); for(int j=3;j>=0;j--) for(int i=0;i<=3;i++) if(pane[i][j]==0) { pane[i][j]=newnumber; return; }}void addnewnumberright() //右移后添加新数{ srand( (unsigned)time( NULL ) ); int n; if(N==1) n=1; else n=(rand()%(N)+1); int newnumber=pow(2,n); for(int j=0;j<=3;j++) for(int i=0;i<=3;i++) if(pane[i][j]==0) { pane[i][j]=newnumber; return; }}int GetDirection() //读取方向{ int ret = 0; do { int ch = _getch(); if(isascii(ch)) continue; ch = _getch(); switch(ch) { case 72: ret = 2; // top break; case 75: ret = 1; // left break; case 77: ret = 3; // right break; case 80: ret = 4; // down break; default: break; } } while (ret == 0); return ret;}int main() //主函数{ system("color f9"); int makesure=1; while(makesure) { system("cls"); newgame(); while(ifwin()+ifGameOver()==0) { int c=GetDirection(); switch(c) { case 2: if(testup()==1) { upmove(); addnewnumberup(); system("cls"); showpane(); } break; case 4: if(testdown()==1) { downmove(); addnewnumberdown(); system("cls"); showpane(); } break; case 1: if(testleft()==1) { leftmove(); addnewnumberleft(); system("cls"); showpane(); } break; case 3: if(testright()==1) { rightmove(); addnewnumberright(); system("cls"); showpane(); } break; default: break; } } cout<<setw(43)<<"你的最后成绩为:"<<panemax()<<endl; cout<<setw(60)<<"若要重新开始游戏请输入1,若要结束请输入0。"<<endl; cin>>makesure; while(makesure!=1&&makesure!=0) { cout<<"输入不正确,请重新输入!"<<endl; cin>>makesure; } } cout<<"再见!"<<endl; system("pause"); return 0;}

提醒:《2048C++实现代码》最后刷新时间 2024-03-14 01:05:45,本站为公益型个人网站,仅供个人学习和记录信息,不进行任何商业性质的盈利。如果内容、图片资源失效或内容涉及侵权,请反馈至,我们会及时处理。本站只保证内容的可读性,无法保证真实性,《2048C++实现代码》该内容的真实性请自行鉴别。