热门游戏 2048 C++ 源代码分享

开发 后端 开发工具
2048源代码,前后写了一个多小时吧,大概300行左右,没什么复杂算法,不过实在懒得去优化了,但估计优化完能控制在200行以下,有兴趣的朋友可以自己优化一下。

这游戏前一段时间传的很火,前几天早上上课实在太无聊了,就决定把这游戏自己也写一个。

前后写了一个多小时吧,大概300行左右,没什么复杂算法,不过实在懒得去优化了,但估计优化完能控制在200行以下,有兴趣的朋友可以自己优化一下。

说明:我一开始玩的是IOS APP版的TRHEES,后来才玩的2048,两者在滑动的规则上有些区别,本人这个版本是这两者的结合。

***,祝试玩愉快!

界面丑陋,求不笑。

以下是源代码:

  1. /*By Reason*/ 
  2. #include<iostream>  
  3. #include <iomanip>  
  4. #include<math.h>  
  5. #include<stdlib.h>  
  6. #include<time.h>  
  7. #include <conio.h> //为了读取方向键  
  8. #include<windows.h>  
  9. using namespace std;    
  10. //srand( (unsigned)time( NULL ) ); //随机数种子 不能用在这里  
  11. int pane[4][4]; //棋盘  
  12. int N=1; //2的n次方  
  13. void showpane() //显示棋盘  
  14. {  
  15.  cout<<setw(46)<<"X2048 by Reason"<<endl;  
  16.  cout<<setw(50)<<" |-----------------------|"<<endl;  
  17.  for(int i=0;i<=3;i++)   
  18.  {  
  19.  cout<<setw(24)<<"";  
  20.  for(int j=0;j<=3;j++)  
  21.  {  
  22.  //SetConsoleTextAttribute(GetStdHandle(STD_OUTPUT_HANDLE),FOREGROUND_RED);   
  23.  cout<<setw(2)<<"|"<<setw(4)<<pane[i][j];  
  24.    
  25.  if(j==3)  
  26.  {  
  27.  cout<<setw(2)<<"|"<<endl;  
  28.  cout<<setw(50)<<" |-----------------------|"<<endl;  
  29.  }  
  30.  }  
  31.  }  
  32. }  
  33. void newgame() //开始游戏  
  34. {  
  35.  N=1;  
  36.  for(int i=0;i<=3;i++) //初始化棋盘  
  37.  for(int j=0;j<=3;j++)  
  38.  pane[i][j]=0;  
  39.  srand( (unsigned)time( NULL ) );  
  40.  int m=rand()%4;  
  41.  int n=rand()%4;  
  42.  int p=rand()%4;  
  43.  int q=rand()%4;  
  44.  pane[m][n]=pane[p][q]=2;  
  45.  showpane();  
  46. }  
  47. int if2n(int x) //判断x是否是2的n次方  
  48. {  
  49.  int flag=0;  
  50.  for(int n=1;n<=11;n++)  
  51.  {  
  52.  if(x==pow(2,n))  
  53.  {  
  54.  flag=1;  
  55.  if(n>N)  
  56.  N=n;  
  57.  return flag;  
  58.  }  
  59.  }  
  60.  return flag;  
  61. }  
  62. int upmove() //上移  
  63. {  
  64.  int flag=0;  
  65.  for(int j=0;j<=3;j++)  
  66.  for(int i=0;i<3;i++)  
  67.  {  
  68.  if(if2n(pane[i][j]+pane[i+1][j])==1)  
  69.  {  
  70.  pane[i][j]=pane[i][j]+pane[i+1][j];  
  71.  pane[i+1][j]=0;  
  72.  flag=1;  
  73.  }  
  74.  }  
  75.  return flag;  
  76. }  
  77. int downmove() //下移  
  78. {  
  79.  int flag=0;  
  80.  for(int j=0;j<=3;j++)  
  81.  for(int i=3;i>0;i--)  
  82.  {  
  83.  if(if2n(pane[i][j]+pane[i-1][j])==1)  
  84.  {  
  85.  pane[i][j]=pane[i][j]+pane[i-1][j];  
  86.  pane[i-1][j]=0;  
  87.  flag=1;  
  88.  }  
  89.  }  
  90.  return flag;  
  91. }  
  92. int leftmove() //左移  
  93. {  
  94.  int flag=0;  
  95.  for(int i=0;i<=3;i++)  
  96.  for(int j=0;j<3;j++)  
  97.  {  
  98.  if(if2n(pane[i][j]+pane[i][j+1])==1)  
  99.  {  
  100.  pane[i][j]=pane[i][j]+pane[i][j+1];  
  101.  pane[i][j+1]=0;  
  102.  flag=1;  
  103.  }  
  104.  }  
  105.  return flag;  
  106. }  
  107. int rightmove() //右移  
  108. {  
  109.  int flag=0;  
  110.  for(int i=0;i<=3;i++)  
  111.  for(int j=3;j>0;j--)  
  112.  {  
  113.  if(if2n(pane[i][j]+pane[i][j-1])==1)  
  114.  {  
  115.  pane[i][j]=pane[i][j]+pane[i][j-1];  
  116.  pane[i][j-1]=0;  
  117.  flag=1;  
  118.  }  
  119.  }  
  120.  return flag;  
  121. }  
  122. int testup() //能否上移测试  
  123. {  
  124.  int flag=0;  
  125.  for(int j=0;j<=3;j++)  
  126.  for(int i=0;i<3;i++)  
  127.  {  
  128.  if(if2n(pane[i][j]+pane[i+1][j])==1)  
  129.  {  
  130.  flag=1;  
  131.  }  
  132.  }  
  133.  return flag;  
  134. }  
  135. int testdown() //测试能否下移  
  136. {  
  137.  int flag=0;  
  138.  for(int j=0;j<=3;j++)  
  139.  for(int i=3;i>0;i--)  
  140.  {  
  141.  if(if2n(pane[i][j]+pane[i-1][j])==1)  
  142.  {  
  143.  flag=1;  
  144.  }  
  145.  }  
  146.  return flag;  
  147. }  
  148. int testleft() //测试能否左移  
  149. {  
  150.  int flag=0;  
  151.  for(int i=0;i<=3;i++)  
  152.  for(int j=0;j<3;j++)  
  153.  {  
  154.  if(if2n(pane[i][j]+pane[i][j+1])==1)  
  155.  {  
  156.  flag=1;  
  157.  }  
  158.  }  
  159.  return flag;  
  160. }  
  161. int testright() //测试能否右移  
  162. {  
  163.  int flag=0;  
  164.  for(int i=0;i<=3;i++)  
  165.  for(int j=3;j>0;j--)  
  166.  {  
  167.  if(if2n(pane[i][j]+pane[i][j-1])==1)  
  168.  {  
  169.  flag=1;  
  170.  }  
  171.  }  
  172.  return flag;  
  173. }  
  174. int panemax() //棋盘***数  
  175. {  
  176.  int max=pane[0][0];  
  177.  for(int i=0;i<=3;i++)  
  178.  for(int j=0;j<=3;j++)  
  179.  if(pane[i][j]>max)  
  180.  max=pane[i][j];  
  181.  return max;  
  182. }  
  183. int ifwin() //判断是否胜利  
  184. {  
  185.  int flag=0;  
  186.  if(panemax()==2048)  
  187.  {  
  188.  cout<<setw(45)<<"You Win!"<<endl;  
  189.  flag=1;  
  190.  }  
  191.  return flag;  
  192. }  
  193. int ifGameOver() //判断是否游戏结束  
  194. {  
  195.  int flag=0;  
  196.  if(testup()+ testdown() + testleft() + testright() ==0)  
  197.  {  
  198.  cout<<setw(43)<<"Game Over!"<<endl;  
  199.  flag=1;  
  200.  }  
  201.  return flag;  
  202. }  
  203. void addnewnumberup() //上移后添加新数  
  204. {  
  205.  srand( (unsigned)time( NULL ) );  
  206.  int n;  
  207.  if(N==1)  
  208.  n=1;  
  209.  else 
  210.  n=(rand()%(N)+1);   
  211.  int newnumber=pow(2,n);  
  212.  for(int i=3;i>=0;i--)  
  213.  for(int j=0;j<=3;j++)  
  214.  if(pane[i][j]==0)  
  215.  {  
  216.  pane[i][j]=newnumber;  
  217.  return;  
  218.  }  
  219. }  
  220. void addnewnumberdown() //下移后添加新数  
  221. {  
  222.  srand( (unsigned)time( NULL ) );  
  223.  int n;  
  224.  if(N==1)  
  225.  n=1;  
  226.  else 
  227.  n=(rand()%(N)+1); int newnumber=pow(2,n);  
  228.  for(int i=0;i<=3;i++)  
  229.  for(int j=0;j<=3;j++)  
  230.  if(pane[i][j]==0)  
  231.  {  
  232.  pane[i][j]=newnumber;  
  233.  return;  
  234.  }  
  235. }  
  236. void addnewnumberleft() //左移后添加新数  
  237. {  
  238.  srand( (unsigned)time( NULL ) );  
  239.  int n;  
  240.  if(N==1)  
  241.  n=1;  
  242.  else 
  243.  n=(rand()%(N)+1);   
  244.  int newnumber=pow(2,n);  
  245.  for(int j=3;j>=0;j--)  
  246.  for(int i=0;i<=3;i++)  
  247.  if(pane[i][j]==0)  
  248.  {  
  249.  pane[i][j]=newnumber;  
  250.  return;  
  251.  }  
  252. }  
  253. void addnewnumberright() //右移后添加新数  
  254. {  
  255.  srand( (unsigned)time( NULL ) );  
  256.  int n;  
  257.  if(N==1)  
  258.  n=1;  
  259.  else 
  260.  n=(rand()%(N)+1);   
  261.  int newnumber=pow(2,n);  
  262.  for(int j=0;j<=3;j++)  
  263.  for(int i=0;i<=3;i++)  
  264.  if(pane[i][j]==0)  
  265.  {  
  266.  pane[i][j]=newnumber;  
  267.  return;  
  268.  }  
  269. }  
  270. int GetDirection() //读取方向  
  271. {  
  272.     int ret = 0;  
  273.    
  274.     do   
  275.     {  
  276.         int ch = _getch();  
  277.         if(isascii(ch))  
  278.             continue;  
  279.    
  280.         ch = _getch();  
  281.         switch(ch)  
  282.         {  
  283.         case 72:     
  284.             ret = 2; // top  
  285.             break;  
  286.         case 75:     
  287.             ret = 1; // left   
  288.             break;  
  289.         case 77:     
  290.             ret = 3; // right  
  291.             break;  
  292.         case 80:     
  293.             ret = 4; // down  
  294.             break;  
  295.         default:     
  296.             break;  
  297.         }  
  298.     } while (ret == 0);  
  299.        
  300.     return ret;  
  301. }  
  302. void main() //主函数  
  303. {  
  304.  system("color f9");  
  305.  int makesure=1;  
  306.  while(makesure)  
  307.  {   
  308.  system("cls");  
  309.  newgame();  
  310.  while(ifwin()+ifGameOver()==0)  
  311.  {  
  312.  int c=GetDirection();  
  313.  switch(c)  
  314.  {  
  315.  case 2:  
  316.  upmove();  
  317.  addnewnumberup();  
  318.  system("cls");  
  319.  showpane();  
  320.  break;  
  321.  case 4:  
  322.  downmove();  
  323.  addnewnumberdown();  
  324.  system("cls");  
  325.  showpane();  
  326.  break;  
  327.  case 1:  
  328.  leftmove();  
  329.  addnewnumberleft();  
  330.  system("cls");  
  331.  showpane();  
  332.  break;  
  333.  case 3:  
  334.  rightmove();  
  335.  addnewnumberright();  
  336.  system("cls");  
  337.  showpane();  
  338.  break;  
  339.  default:     
  340.  break;  
  341.  }  
  342.  }  
  343.  cout<<setw(43)<<"你的***成绩为:"<<panemax()<<endl;  
  344.  cout<<setw(60)<<"若要重新开始游戏请输入1,若要结束请输入0。"<<endl;  
  345.  cin>>makesure;  
  346.  while(makesure!=1&&makesure!=0)  
  347.  {  
  348.  cout<<"输入不正确,请重新输入!"<<endl;  
  349.  cin>>makesure;  
  350.  }  
  351.  }  
  352.  cout<<"再见!"<<endl;  
  353.  system("pause");  
  354.    

原文链接:http://my.oschina.net/chenreason/blog/216003

责任编辑:林师授 来源: OSCHINA
相关推荐

2014-04-08 15:16:07

2048算法分析算法

2010-01-26 13:14:48

2020-07-07 10:55:01

C++C语言代码

2010-01-14 10:42:08

C++源代码

2014-06-19 10:02:32

Haskell代码

2010-01-11 16:59:50

C++源代码

2012-01-10 12:48:52

Java

2023-11-06 07:51:24

C++线程编程

2010-02-01 11:13:00

C++ Traits

2010-02-05 18:09:28

C++ Doxygen

2011-07-13 16:36:11

C++

2011-04-11 15:06:22

C++关键字

2020-11-12 09:44:43

鸿蒙

2011-07-13 17:42:32

CC++

2018-06-15 11:22:52

Python分析世界杯

2011-07-13 17:08:02

CC++

2011-07-13 16:48:55

CC++

2023-08-07 15:18:29

游戏开发鸿蒙Arkts

2023-10-30 10:29:50

C++最小二乘法

2010-02-06 13:47:08

C++标准扩展
点赞
收藏

51CTO技术栈公众号