[数据结构]游戏2048 解题报告

Problem Description

《2048》是一款数字益智游戏,在4*4的方格中通过上下左右滑动来控制数字的变化,游戏胜利的条件是出现2048这个数字。
游戏规则如下:
1、玩家每次可以选择上下左右其中一个方向去滑动,定义滑动的方向为前,滑动的反方向为后,每滑动一次,所有的数字方块都会向前移动靠拢至边缘。
2、每一行(列)从最前方第二个方块依次向前方方块发起撞击,相撞的两个方块数字不同时不发生变化,撞击发起块向后顺延,相撞的两个方块相同时变成一个新的数值相加的数字块,后续的数字块依次向前递补空位,撞击发起块变为新生成数字块的后面第二个数字块。
3、撞击结束后系统会在空白的地方随机出现一个数字方块2或者4。
对4 * 4方格中的16格分别赋予编号 1-16
1 2 3 4
5 6 7 8
9 10 11 12
13 14 15 16

初始状态:


初始状态

当玩家游戏一段时间后,出现状态1,
状态1:


状态1

此时玩家向右滑动,出现状态2,
状态2:


状态2

当玩家游戏一段时间后出现状态3:
状态3:


状态3

在状态3的情况下向下滑动出现状态4
状态4:


状态4

本题输入:

输入1 :
按格子编号1-16输入2048游戏的一个状态序列,编号对应的格子没有数字则输入0,如输入
0 0 0 0 4 0 2 0 4 0 2 2 2 8 8 8 表示状态1
输入2:一个用户操作和新增块地址序列,a表示向左滑动,s表示向下滑动,d表示向右滑动,w表示向上滑动
如输入 w 1 2 a 5 4 s 11 2 d 13 4 d 9 2 ,表示用户依次进行了如下5次操作:
玩家向上滑动一次,之后在编号1的位置新出现一个数值为2的新增块
玩家向左滑动一次,之后在编号5的位置新出现一个数值为4的新增块
玩家向下滑动一次,之后在编号11的位置新出现一个数值为2的新增块
玩家向右滑动一次,之后在编号13的位置新出现一个数值为4的新增块
玩家向右滑动一次,之后在编号9的位置新出现一个数值为2的新增块
如果编号所在的位置不为空,则修改 编号 = 编号%16+1,并探索编号所在位置是否为空,弱编号位置不为空,则重复 编号 = 编号%16+1,直至探索编号位置为空,并增加新增块

输出:从编号1到编号16方格的数字,格子为空则输出0
PS: 有兴趣的同学可以自行补全 胜利判断、随机数出现功能,完成一个完整的2048游戏。


测试输入

0 0 0 0 0 0 4 4 4 4 8 16 4 8 16 16
a 6 2

测试输出

0 0 0 0 8 2 0 0 8 8 16 0 4 8 32 0

AcCode

//
//  main.cpp
//  游戏2048
//
//  Created by jetviper on 2017/3/26.
//  Copyright © 2017年 jetviper. All rights reserved.
//

#pragma warning(disable:4996)
#include<stdio.h>
int chess[18];
void move(int a, int b, int c, int d);
void check(char t, int from, int to){
    switch (t) {
    case 'w': {
        move(1, 5, 9, 13);
        move(2, 6, 10, 14);
        move(3, 7, 11, 15);
        move(4, 8, 12, 16);
        break;
    }
    case 'a': {
        move(1, 2, 3, 4);
        move(5, 6, 7, 8);
        move(9, 10, 11, 12);
        move(13, 14, 15, 16);
        break;
    }
    case 's': {
        move(13, 9, 5, 1);
        move(14, 10, 6, 2);
        move(15, 11, 7, 3);
        move(16, 12, 8, 4);
        break;
    }
    case 'd': {
        move(4, 3, 2, 1);
        move(8, 7, 6, 5);
        move(12, 11, 10, 9);
        move(16, 15, 14, 13);
        break;
    }
}
    int flag = 0;
    while (flag == 0) {
        if (chess[from] == 0) {chess[from] = to;flag = 1;
        }
        else {from = from % 16 + 1;continue;}
    }
}
void move(int a, int b, int c, int d) {
    int t[5], k, s[5] = { 0,0,0,0 };
    t[0] = chess[a];
    t[1] = chess[b];
    t[2] = chess[c];
    t[3] = chess[d];
    k = 0;
    
    for (int i = 0; i < 4; i++) {
        if (t[i] != 0) {
            s[k] = t[i];
            k++;
        }
    }
    
    if (s[0] == s[1]) {
        s[0] *= 2;
        s[1] = s[2];
        s[2] = s[3];
        s[3] = 0;
    }
    if (s[1] == s[2]) {
        s[1] *= 2;
        s[2] = s[3];
        s[3] = 0;
    }
    if (s[2] == s[3]) {
        s[2] *= 2;
        s[3] = 0;
    }
    chess[a] = s[0];
    chess[b] = s[1];
    chess[c] = s[2];
    chess[d] = s[3];
    
}
int main(){
    int from, to;
    char t,temp;
    for (int i = 1; i <= 16; i++)scanf("%d\n", &chess[i]);
    
    while ((temp = getchar()) != '\n'){
        if (temp == ' ')continue;
        t = temp;
        scanf("%d%d", &from, &to);
        check(t, from, to);}
    for (int i = 1; i <= 16; i++){
        if (i == 1)printf("%d", chess[i]);
        else printf(" %d", chess[i]);
    }
    printf("\n");
}

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 202,905评论 5 476
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,140评论 2 379
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 149,791评论 0 335
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,483评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,476评论 5 364
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,516评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,905评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,560评论 0 256
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,778评论 1 296
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,557评论 2 319
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,635评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,338评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,925评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,898评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,142评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,818评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,347评论 2 342

推荐阅读更多精彩内容