/*
dos windows 25*80
*/
#include <algorithm>
#include <windows.h>
#include <iostream>
#include <cstring>
#include <cstdlib>
#include <conio.h>
#include <ctype.h>
#include <cstdio>
#include <cmath>
#include <ctime>
using namespace std;
int game_answer=0; /*
1 = 蓝色 9 = 淡蓝色
2 = 绿色 10 = 淡绿色
3 = 湖蓝色 11 = 淡浅绿色
4 = 红色 12 = 淡红色
5 = 紫色 13 = 淡紫色
6 = 黄色 14 = 淡黄色
7 = 白色 15 = 亮白色
*/
/*设置背景颜色*/int setBackColor(unsigned char bColor){
HANDLE hd = GetStdHandle(STD_OUTPUT_HANDLE);
CONSOLE_SCREEN_BUFFER_INFO csbInfo;
GetConsoleScreenBufferInfo(hd, &csbInfo);
return SetConsoleTextAttribute(hd, (bColor << 4) | (csbInfo.wAttributes&~0xF0));
}
/*设置字体颜色*/int setTextColor(unsigned char fColor){
HANDLE hd = GetStdHandle(STD_OUTPUT_HANDLE);
CONSOLE_SCREEN_BUFFER_INFO csbInfo;
GetConsoleScreenBufferInfo(hd, &csbInfo);
return SetConsoleTextAttribute(hd, fColor | (csbInfo.wAttributes&~0x0F));
} void appGetXY() //得到光标位置
{
HANDLE hStdout;
CONSOLE_SCREEN_BUFFER_INFO pBuffer;
hStdout = GetStdHandle(STD_OUTPUT_HANDLE);
GetConsoleScreenBufferInfo(hStdout, &pBuffer);
cout << pBuffer.dwCursorPosition.X <<" "<< pBuffer.dwCursorPosition.Y <<endl;;
}
void appGotoXY(int x,int y) //移动光标
{
swap(x,y);
CONSOLE_SCREEN_BUFFER_INFO csbiInfo;
HANDLE hConsoleOut;
hConsoleOut = GetStdHandle(STD_OUTPUT_HANDLE);
GetConsoleScreenBufferInfo(hConsoleOut,&csbiInfo);
csbiInfo.dwCursorPosition.X = x;
csbiInfo.dwCursorPosition.Y = y;
SetConsoleCursorPosition(hConsoleOut,csbiInfo.dwCursorPosition);
}
inline int Get_X(int x,int y){
if(x==1) return 5;
if(x==2) return 9;
if(x==3) return 13;
if(x==4) return 17;
}
inline int Get_Y(int x,int y){
if(y==1) return 24;
if(y==2) return 34;
if(y==3) return 44;
if(y==4) return 54;
} void HideCursor(){//隐藏光标
CONSOLE_CURSOR_INFO cursor_info = {1, 0};
SetConsoleCursorInfo(GetStdHandle(STD_OUTPUT_HANDLE), &cursor_info);
} int a[5][5];
bool if_game_over(){
for(int i=1;i<=4;i++)
for(int j=1;j<=4;j++)
if(!a[i][j])
return 1;
for(int i=2;i<=4;i++)
for(int j=1;j<=4;j++){
if(a[j][i]==a[j][i-1])
return 1;
if(a[i][j]==a[i-1][j])
return 1;
}
return 0;
}
bool vis[20]; void Pr_a_num_with_color(int x){
switch (x){/*
1 = 蓝色 9 = 淡蓝色
2 = 绿色 10 = 淡绿色
3 = 湖蓝色 11 = 淡浅绿色
4 = 红色 12 = 淡红色
5 = 紫色 13 = 淡紫色
6 = 黄色 14 = 淡黄色
7 = 白色 15 = 亮白色*/
case 2:setTextColor(9);printf("%4d",x);setTextColor(0);break ;
case 4:setTextColor(10);printf("%4d",x);setTextColor(0);break ;
case 8:setTextColor(11);printf("%4d",x);setTextColor(0);break ;
case 16:setTextColor(12);printf("%4d",x);setTextColor(0);break ;
case 32:setTextColor(13);printf("%4d",x);setTextColor(0);break ;
case 64:setTextColor(14);printf("%4d",x);setTextColor(0);break ;
case 128:setTextColor(15);printf("%4d",x);setTextColor(0);break ;
case 256:setTextColor(1);printf("%4d",x);setTextColor(0);break ;
case 512:setTextColor(2);printf("%4d",x);setTextColor(0);break ;
case 1024:setTextColor(3);printf("%4d",x);setTextColor(0);break ;
case 2048:setTextColor(4);printf("%4d",x);setTextColor(0);break ;
case 4096:setTextColor(5);printf("%4d",x);setTextColor(0);break ;
}
} void Pr_all_num(){
for(int i=1;i<=4;i++)
for(int j=1;j<=4;j++){
int x=Get_X(i,j),y=Get_Y(i,j);
appGotoXY(x,y);
if(a[i][j]==0)
printf(" ");
else{
Pr_a_num_with_color(a[i][j]);
//printf("%4d",a[i][j]);
}
}
return ;
}
//**************************************************
bool clear_up(){
bool bb=0;
for(int k=1;k<=4;k++)
for(int i=3;i>=1;i--)
for(int j=1;j<=4;j++)
if(a[i][j]==0&&a[i+1][j]!=0){
swap(a[i][j],a[i+1][j]);
bb=1;
}
if(bb==1)
return 1;
return 0;
}
bool do_up(){
if(!if_game_over())
return 1;
bool bb=1;
if(!clear_up())//没空间不能移动
bb=0;
for(int j=1;j<=4;j++){
int i=1;
while(i<4){
if(!a[i+1][j])
break ;
if(a[i][j]!=a[i+1][j]){
i++;
continue ;
}
if(a[i][j]==a[i+1][j]){
a[i][j]+=a[i+1][j]; game_answer+=a[i+1][j];
a[i+1][j]=0;
i+=2;
bb=1;//可以合并
}
}
}
if(bb==0)//没空间又不能合并
return 0;
clear_up();
return 1;
}
//**************************************************
bool clear_down(){
bool bb=0;
for(int k=1;k<=4;k++)
for(int i=2;i<=4;i++)
for(int j=1;j<=4;j++)
if(a[i][j]==0&&a[i-1][j]!=0){
swap(a[i][j],a[i-1][j]);
bb=1;
}
if(bb==1)
return 1;
return 0;
}
bool do_down(){
if(!if_game_over())
return 1;
bool bb=1;
if(!clear_down())
bb=0;
for(int j=1;j<=4;j++){
int i=4;
while(i>1){
if(!a[i-1][j])
break ;
if(a[i][j]!=a[i-1][j]){
i--;
continue ;
}
if(a[i][j]==a[i-1][j]){
a[i][j]+=a[i-1][j]; game_answer+=a[i-1][j];
a[i-1][j]=0;
i-=2;
bb=1;
}
}
}
if(bb==0)
return 0;
clear_down();
return 1;
}
//**************************************************
bool clear_left(){
bool bb=0;
for(int k=1;k<=4;k++)
for(int i=1;i<=4;i++)
for(int j=3;j>=1;j--)
if(a[i][j]==0&&a[i][j+1]!=0){
swap(a[i][j],a[i][j+1]);
bb=1;
}
if(bb==1)
return 1;
return 0;
}
bool do_left(){
if(!if_game_over())
return 1;
bool bb=1;
if(!clear_left())
bb=0;
for(int i=1;i<=4;i++){
int j=1;
while(j<4){
if(!a[i][j+1])
break ;
if(a[i][j]!=a[i][j+1]){
j++;
continue ;
}
if(a[i][j]==a[i][j+1]){
a[i][j]+=a[i][j+1]; game_answer+=a[i][j+1];
a[i][j+1]=0;
j+=2;
bb=1;
}
}
}
if(bb==0)
return 0;
clear_left();
return 1;
}
//**************************************************
bool clear_right(){
bool bb=0;
for(int k=1;k<=4;k++)
for(int i=1;i<=4;i++)
for(int j=2;j<=4;j++)
if(a[i][j]==0&&a[i][j-1]!=0){
swap(a[i][j],a[i][j-1]);
bb=1;
}
if(bb==1)
return 1;
return 0;
}
bool do_right(){
if(!if_game_over())
return 1;
bool bb=1;
if(!clear_right())
bb=0;
for(int i=1;i<=4;i++){
int j=4;
while(j>1){
if(!a[i][j-1])
break ;
if(a[i][j]!=a[i][j-1]){
j--;
continue ;
}
if(a[i][j]==a[i][j-1]){
a[i][j]+=a[i][j-1]; game_answer+=a[i][j-1];
a[i][j-1]=0;
j-=2;
bb=1;
}
}
}
if(bb==0)
return 0;
clear_right();
return 1;
} void START();
void END(); int main(){
srand(time(0));
HideCursor();//隐藏光标 START(); while(if_game_over()){
//system("cls");
//appGotoXY(0,0); int bb=0;//bb判断是否有空位
for(int i=1;i<=4;i++)
for(int j=1;j<=4;j++)
if(!a[i][j])
bb=1;
if(bb==1){
int num_new=rand()%10+1;//新出现4还是2
if(num_new==1) num_new=4;
else num_new=2;
int place_new=0,x=0,y=0;
while(1){
place_new=rand()%16+1;
x=(place_new-1)/4+1,y=place_new%4+1;
if(!a[x][y])
break ;
}
a[x][y]=num_new;
} Pr_all_num(); again:
char ch_1=getch(),ch_2;
if(ch_1!=-32){
appGotoXY(20,30);
char s_1[30]="您输入的字符不合法。";
for(int i=0;i<20;i++){
cout<<s_1[i];
Sleep(1);
}
Sleep(200);
for(int i=1;i<=19;i++)
printf("\b \b");
goto again;
}
ch_2=getch();
if(ch_2==72)//up
if(!do_up())
goto again;
if(ch_2==80)//down
if(!do_down())
goto again;
if(ch_2==75)//left
if(!do_left())
goto again;
if(ch_2==77)//right
if(!do_right())
goto again;
appGotoXY(20,30);
printf("您当前的总分为:%d",game_answer);
}
appGotoXY(20,30);
printf(" ");
END();
return 0;
}
void START(){
appGotoXY(0,0);
setBackColor(15);//大背景颜色
for(int i=1;i<=26*80;i++)
cout<<" ";
appGotoXY(0,0);
cout<<" ";
appGotoXY(20,19);
setBackColor(7);//小背景颜色
for(int i=1;i<=42;i++)
cout<<" ";
setTextColor(0);//字体颜色
appGotoXY(3,19);
printf("┏━━━━┳━━━━┳━━━━┳━━━━┓\n");
appGotoXY(4,19);
printf("┃ ┃ ┃ ┃ ┃\n");
appGotoXY(5,19);
printf("┃ ┃ ┃ ┃ ┃\n");
appGotoXY(6,19);
printf("┃ ┃ ┃ ┃ ┃\n");
appGotoXY(7,19);
printf("┣━━━━╋━━━━╋━━━━╋━━━━┫\n");
appGotoXY(8,19);
printf("┃ ┃ ┃ ┃ ┃\n");
appGotoXY(9,19);
printf("┃ ┃ ┃ ┃ ┃\n");
appGotoXY(10,19);
printf("┃ ┃ ┃ ┃ ┃\n");
appGotoXY(11,19);
printf("┣━━━━╋━━━━╋━━━━╋━━━━┫\n");
appGotoXY(12,19);
printf("┃ ┃ ┃ ┃ ┃\n");
appGotoXY(13,19);
printf("┃ ┃ ┃ ┃ ┃\n");
appGotoXY(14,19);
printf("┃ ┃ ┃ ┃ ┃\n");
appGotoXY(15,19);
printf("┣━━━━╋━━━━╋━━━━╋━━━━┫\n");
appGotoXY(16,19);
printf("┃ ┃ ┃ ┃ ┃\n");
appGotoXY(17,19);
printf("┃ ┃ ┃ ┃ ┃\n");
appGotoXY(18,19);
printf("┃ ┃ ┃ ┃ ┃\n");
appGotoXY(19,19);
printf("┗━━━━┻━━━━┻━━━━┻━━━━┛\n");
//Sleep(100000);
return ;
}
void END(){
setBackColor(15);
appGotoXY(21,30);
char s_1[30]="游戏结束,您的得分为:";
for(int i=0;i<22;i++){
cout<<s_1[i];
Sleep(30);
}
Sleep(500);
cout<<game_answer<<endl;
Sleep(500);
appGotoXY(22,30);
char s_2[30]="请按任意键结束游戏。";
for(int i=0;i<20;i++){
cout<<s_2[i];
Sleep(30);
}
}

【IOI2019】2048矩形模拟的更多相关文章

  1. [CSP-S模拟测试]:小P的2048(模拟)

    题目描述 最近,小$P$迷上了一款叫做$2048$的游戏.这块游戏在一个$n\times n$的棋盘中进行,棋盘的每个格子中可能有一个形如$2^k(k\in N^*)$的数,也可能是空的.游戏规则介绍 ...

  2. WPF 自定义文本框输入法 IME 跟随光标

    本文告诉大家在 WPF 写一个自定义的文本框,如何实现让输入法跟随光标 本文非小白向,本文适合想开发自定义的文本框,从底层开始开发的文本库的伙伴.在开始之前,期望了解了文本库开发的基础知识 本文实现的 ...

  3. android 模拟2048

    利用节日休息时间在ANDROID上进行学习并模拟2048游戏. 效果如下图: 制作思路: 1.画出2048游戏主界面,根据手机屏幕宽高度进行计算并画出每个方块的大小. @Override protec ...

  4. 【noip模拟赛 sword,zero,2048】 题解

    1.光剑 (sword.pas/c/cpp) [题目描述] 小林和亮亮各有一把光剑,长度分别为 a 和 b,他们拿光剑进行比试.每一回合,长光剑会砍向短光剑,砍完后,短光剑完好无损,而长光剑则被截成两 ...

  5. csps模拟测试7273简单的操作小P的2048小P的单调数列小P的生成树

    题面:https://www.cnblogs.com/Juve/articles/11678564.html 简单的操作: 考场上sb了,没看出来 如果有奇环一定不能缩成一条链,判掉奇环后就是bfs最 ...

  6. 「10.14」小P的2048(模拟)·小P的单调数列(性质,DP)·小P的生成树(乱搞)

    A. 小P的2048 模拟.....又没啥可说的,以后要认真打打模拟题了... B. 小P的单调数列 考场$n^2log(n)$的SB思路有人听吗 正解当然不是这样, 事实上我们每次选取的只有一段区间 ...

  7. LYDSY模拟赛day9 2048

    /* 大模拟题,做的时候思路还是比较清晰的 */ #include<iostream> #include<cstdio> #include<string> #inc ...

  8. 【noip模拟】2048

     Time limit: 1000ms         Memory limits: 256MB Description 2048曾经是一款风靡全球的小游戏.今天,我们换一种方式来玩这个小游戏.现在, ...

  9. ccf认证模拟题之三---最大的矩形

    问题描述 在横轴上放了n个相邻的矩形,每个矩形的宽度是1,而第i(1 ≤ i ≤ n)个矩形的高度是hi.这n个矩形构成了一个直方图.例如,下图中六个矩形的高度就分别是3, 1, 6, 5, 2, 3 ...

随机推荐

  1. hdu 6185 递推+矩阵快速幂

    思路:考虑全部铺满时,前2列的放法.有如下5种情况:(转自http://blog.csdn.net/elbadaernu/article/details/77825979 写的很详细 膜一下)  假设 ...

  2. 刷新ip地址 windows linux系统

    linux:使用dhcp去更新ip与释放ip 释放ip: dhclient -r eth0 (释放eth0的ip) 更新ip : dhclient eth0 (针对eth0,请求新的ip) windo ...

  3. RabbitMQ集群部署、高可用和持久化

    RabbitMQ 安装和使用 1.安装依赖环境 在 http://www.rabbitmq.com/which-erlang.html 页面查看安装rabbitmq需要安装erlang对应的版本 在 ...

  4. GoLand中同一个目录下的package无法调用

    代码结构: 三个代码的package 都是 pipefilter,执行split_filter_test.go 就会提示   undefined:xxxxxxx Golang实际都可以自己补全另一个文 ...

  5. axios 发 post 请求,后端接收不到参数的解决方案(转载)

    原文地址:https://www.cnblogs.com/yiyi17/p/9409249.html 问题场景 场景很简单,就是一个正常 axios post 请求: axios({ headers: ...

  6. 基于【 建造者模式】一 || 网关zuul过滤器封装

    一.springcloud的zuul网关拦截 1.黑名单拦截 2.参数验签 3.Api接口权限验证 二.网关拦截实现方式 1.继承ZuulFilter方法,实现业务逻辑 @Component @Slf ...

  7. iOS - error:unrecognized selector sent to class 导入第三方SDK .a后不识别,运行崩溃

    今天将app统计的.a静态库包含到一个app应用中,调试时报下面的错误: *** Terminating app due to uncaught exception 'NSInvalidArgumen ...

  8. Vue指令之`v-if`和`v-show`

    一般来说,v-if 有更高的切换消耗而 v-show 有更高的初始渲染消耗.因此,如果需要频繁切换 v-show 较好,如果在运行时条件不大可能改变 v-if 较好. <body> < ...

  9. 常见User-Agent大全

    window.navigator.userAgent 1) Chrome Win7: Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKit/535.1 (KH ...

  10. java - day012 - 异常 , throws, throw , IO ,RandomAccessFile

    异常 封装错误信息的对象 错误信息 类型        例如: NullPointerExce 空指针 提示消息  出错的行号 异常的继承结构 Throwable | - Error 系统级错误 | ...