I - 2048

 

I - 2048

Time Limit: 2000/1000 MS (Java/Others)      Memory Limit: 128000/64000 KB (Java/Others)
Submit Status

Problem Description

      《2048》是一款比较流行的数字游戏,最早于2014年3月20日发行。原版2048首先在GitHub上发布,原作者是Gabriele Cirulli,后被移植到各个平台。这款游戏是基于《1024》和《小3传奇》的玩法开发而成的新型数字游戏。

       这是20岁的Gabriele Cirulli开发的一款数字游戏。初衷就是觉得好玩,在将其开源版本放到Github上后,意外走红。这款游戏的玩法很简单,每次可以选择上下左右滑动,每滑动一次,所有的数字方块都会往滑动的方向靠拢,系统也会在空白的地方乱数出现一个数字方块,相同数字的方块在靠拢、相撞时会相加。不断的叠加最终拼凑出2048这个数字就算成功。

    现在要你编程模拟这个游戏的移动过程,每次输入一个字母c表示移动方向,然后再输入一个4*4的矩阵,表示一个游戏局面,然后你要输出一个4*4的矩阵表示移动后的局面。

    例如

    向下移动之后变成:

Input

多组样例输入。

每组样例第一行输入一个字母c,c∈{U,D,L,R}

接下来4行输入一个4*4的矩阵,矩阵中每个数都为0或2k,1<=k<=16,其中0表示空格

Output

第一行输出Case x:

x表示第几个样例

接下来输出四行,一个4*4的矩阵,表示移动后的局面(不考虑移动后在空位出现一个新数字)

Sample Input

D
0 4 2 8
2 0 2 4
0 0 4 16
2 8 4 64
R
2 2 2 2
2 0 0 2
2 0 0 2
0 2 2 4
U
2 2 2 2
2 0 0 2
2 0 0 2
0 2 2 4

Sample Output

Case 1:
0 0 0 8
0 0 0 4
0 4 4 16
4 8 8 64
Case 2:
0 0 4 4
0 0 0 4
0 0 0 4
0 0 4 4
Case 3:
4 4 4 4
2 0 0 2
0 0 0 4
0 0 0 0

Hint

碰撞时最靠移动的方向的数先相加,如第三个样例中最后一列,注意第二个样例中的2 2 2 2,移动之后会变成0 0 4 4,即相加生成的数不会再相加
 
 
 1 #include <bits/stdc++.h>
 2 using namespace std;
 3 typedef long long LL;
 4 const int N=1e5+10;
 5 const int INF=0x3f3f3f3f;
 6 int cas=1,T;
 7 int a[4][4],d;
 8 void output(int a[4][4])
 9 {
10     for(int i=0;i<4;i++)
11         for(int j=0;j<4;j++) printf("%d%c",a[i][j],j==3?'\n':' ');
12 }
13 void rotate(int a[4][4],int d)
14 {
15     int t[4][4];
16 //    output(a);printf("\n");
17     for(int i=0;i<d;i++)
18     {
19         memcpy(t,a,sizeof(t));
20         for(int j=0;j<4;j++)
21             for(int k=0;k<4;k++)
22                 a[j][k]=t[k][4-j-1];
23     }
24 //    output(a);printf("\n");
25 }
26 void move(int a[4][4])
27 {
28     for(int i=0;i<4;i++)
29     {
30         for(int j=3;j>0;j--)
31         {
32             if(a[i][j])
33             {
34                 int k=j-1;
35                 while(k>0)
36                 {
37                     if(a[i][k]==0) k--;
38                     else break;
39                 }
40                 if(a[i][k]==a[i][j])
41                 {
42                     a[i][k]=0;
43                     a[i][j]<<=1;
44                 }
45             }
46         }
47         for(int j=3;j>0;j--)
48         {
49             if(!a[i][j]) 
50             {
51                 int k=j-1;
52                 while(k>0)
53                 {
54                     if(a[i][k]==0) k--;
55                     else break;
56                 }
57                 swap(a[i][j],a[i][k]);
58             }
59         }
60     }
61 }
62 char dir[2];
63 int main()
64 {
65 //    freopen("1.in","w",stdout);
66 //    freopen("1.in","r",stdin);
67 //    freopen("1.out","w",stdout);
68 //    scanf("%d",&T);
69     while(scanf("%s",dir)==1)
70     {
71         switch(dir[0])
72         {
73             case 'R':d=0;break;
74             case 'U':d=1;break;
75             case 'L':d=2;break;
76             case 'D':d=3;break;
77         }
78         for(int i=0;i<4;i++)
79             for(int j=0;j<4;j++) scanf("%d",&a[i][j]);
80         rotate(a,4-d);
81         move(a);
82         rotate(a,d);
83         printf("Case %d:\n",cas++);
84         output(a);
85     }
86 //    printf("time=%.3lf\n",(double)clock()/CLOCKS_PER_SEC);
87     return 0;
88 }
89 /*
90 →0
91 ↑1
92 ←2
93 ↓3
94 */
solve.cpp

 

题解:

直接模拟每个方向的移动,注意细节
标程只写了一个方向的移动,然后其它方向的通过旋转实现

 
posted @ 2017-06-14 19:17  cdongyang  阅读(280)  评论(0编辑  收藏  举报