嘉应学院计算机学院实验报告课程名称: C程序设计开课学期: 2015—2016学年第1学期班级:计算机1505 指导老师:陈广明设计题目:游戏2048 学生姓名(学号):第3组:钟瞻宇目录一、实验目的和要求 ....................................................................................................................................................二、实验环境、内容和方法 ........................................................................................................................................三、程序设计 ................................................................................................................................................................四、源代码 ....................................................................................................................................................................五、调试与运行结果....................................................................................................................................................六、总结........................................................................................................................................................................一、实验目的和要求(1)使用C语言编写2048这款游戏。
(2)能够正常运行,拥有游戏界面。
(3)能正常进行游戏从开始到结束。
?(4)用户操作方便。
二、实验环境、内容和方法实验内容:1、游戏开始时随机产生两个数值为2/4的方格,其中一个方格置于4个角中的一个位置,另一个方格随机的置于其他位置,其他方格置于0。
2、每次按方向键(w,s,a,d)后,逐行计算移动后的方格值。
每行移动的算法是:先将所有值为0的数移至行首。
能后从行尾开始逐一和前一个数比较,如果相等则合并这2个格子。
3、每合并一次格子,将其值累计到游戏总分中。
4、一次移动结束后,在所有值为0的方格中随机的分配一个2/4的值。
5、所有方格值不为0且上下、左右相邻的方格都不相等,则游戏结束。
6、2出现的概率为70%,4出现的概率为30%。
实验方法:通过上机操作完成各内容。
实验环境:实验用PC机一台,使用操作系统为Windows 7/ Windows 8/ Windows10,安装vc++或v2008等编译软件三、程序设计YNNY四、源代码#include<stdio.h>#include<stdlib.h>#include<time.h>#include<conio.h>#define M 2048void up(); //上操作。
void down();//下操作。
void right();//右操作。
void left(); //左操作。
void play(); //操作函数。
void random(); //随机函数。
void integral(int x);//积分函数。
void all_printf(); //输出图像函数。
int A[4][4]={0};int C=0; //得分的最终数值。
void main(){printf(" 游戏规则很简单:\n");printf(" 开始时棋盘内随机出现两个数字,出现的数字仅可能为2或4.\n");printf(" 玩家可以选择上(w)下(s)左(a)右(d)四个方向,若棋盘内的数字出现位移或合并,视为有效移动.\n");printf(" 若有相同的数字则合并,每次有效移动可以同时合并,但不可以连续合并.\n");printf(" 合并所得的所有新生成数字想加即为该步的有效得分.\n");printf(" 玩家选择的方向行或列前方有空格则出现位移.\n");printf(" 每有效移动一步,棋盘的空位(无数字处)随机出现一个数字(依然可能为2或4).\n");printf(" 棋盘被数字填满,无法进行有效移动,判负,游戏结束.\n");printf(" 棋盘上出现2048,判胜,游戏结束");printf("\n\n\n");printf(" \t\t\t按回车开始游戏.\n");getchar(\n);system("cls");system("color 70");random();random();all_printf();int flag=1,i,j;char judge;for(;flag==1;){play();for(i=0,flag=0;i<=3;i++){for(j=0;j<=3;j++)if(A[i][j]==0&&(flag==0||flag==1))flag=1;else if(A[i][j]==M)flag=2;}if(flag==0){system("color c7");printf("\n\t\t\t任务失败 !你总共获得%d分!\n",C);}else if(flag==2)printf("\n\t\t\t恭喜你获得胜利 !你总共获得%d分!\n",C);if(flag==0||flag==2){printf("是否重新开始?(y or n):");judge=getch();if(judge=='y'){system("cls");C=0;for(i=0;i<=3;i++)for(j=0;j<=3;j++)A[i][j]=0;random();random();all_printf();flag=1;system("color 70");}else break;}else{random();system("cls");all_printf();printf("\n");printf("\t分数为:%6d\t\t",C);}}}void play() /* 操作函数*/{char direction;direction=getch();switch(direction){case 'w':up();break;case 's':down();break;case 'a':left();break;case 'd':right();break;default: printf("输入错误!\n");}}void up(){int a[4][4]={0},i,j,m;for(j=0;j<=3;j++)for(i=0,m=0;i<=3;i++)if(A[i][j]==0)continue;else a[m++][j]=A[i][j];//A[i][j]的有效值赋给a[i][j],所有有效值向上靠拢。
for(i=0;i<=3;i++)for(j=0;j<=3;j++)A[i][j]=0; //对整个A数组赋0。
for(j=0;j<=3;j++)for(i=0,m=0;i<=3;i++){if(i==3&&a[i][j]!=0)A[m][j]=a[i][j];else if(a[i][j]==0)continue;else if(a[i][j]==a[i+1][j]){A[m++][j]=a[i][j]*2;a[i+1][j]=0;integral(a[i][j]*2);}else if(a[i][j]!=a[i+1][j]){A[m++][j]=a[i][j];}}//分析计算回归赋值。
}// 向上。
void down(){int a[4][4]={0},i,j,m;for(j=0;j<=3;j++)for(i=3,m=3;i>=0;i--)if(A[i][j]==0)continue;else a[m--][j]=A[i][j];//A[i][j]的有效值赋给a[i][j],所有有效值向下靠拢。
for(i=0;i<=3;i++)for(j=0;j<=3;j++)A[i][j]=0;//对整个A数组赋0。
for(j=0;j<=3;j++)for(i=3,m=3;i>=0;i--){if(i==0&&a[i][j]!=0)A[m][j]=a[i][j];else if(a[i][j]==0)continue;else if(a[i][j]==a[i-1][j]){A[m--][j]=a[i][j]*2;a[i-1][j]=0;integral(a[i][j]*2);}else if(a[i][j]!=a[i-1][j]){A[m--][j]=a[i][j];}}//分析计算回归赋值。
}// 向下。
void left(){int a[4][4]={0},i,j,m;for(i=0;i<=3;i++)for(j=0,m=0;j<=3;j++)if(A[i][j]==0)continue;else a[i][m++]=A[i][j];//A[i][j]的有效值赋给a[i][j],所有有效值向左靠拢。