俄罗斯方块(C++)

#include<iostream>
#include<stdlib.h>
#include<windows.h>
#include<time.h>
#include<conio.h>
using namespace std;#define A1 0//A代表长条型,B为方块,C为L型,D为闪电型(实在无法描述那个形状)
#define A2 1#define B 2#define C11 3
#define C12 4
#define C13 5
#define C14 6#define C21 7
#define C22 8
#define C23 9
#define C24 10#define D11 11
#define D12 12#define D21 13
#define D22 14void SetPos(short i,short j)//设定光标位置
{COORD pos={i,j};HANDLE Out=GetStdHandle(STD_OUTPUT_HANDLE);SetConsoleCursorPosition(Out, pos);
}int sharp[15][8]=
{{0,0,1,0,2,0,3,0},{0,0,0,1,0,2,0,3},{0,0,1,0,0,1,1,1},{0,0,1,0,1,1,1,2},{0,1,1,1,2,0,2,1},{0,0,0,1,0,2,1,2},{0,0,0,1,1,0,2,0},{1,0,1,1,1,2,0,2},{0,0,0,1,1,1,2,1},{0,0,0,1,0,2,1,0},{0,0,1,0,2,0,2,1},{0,0,0,1,1,1,1,2},{0,1,1,0,1,1,2,0},{0,1,0,2,1,0,1,1},{0,0,1,0,1,1,2,1}
};//这个2维数组是用来保存各个形状位置的int high[15]={4,1,2,2,3,2,3,2,3,2,3,2,3,2,3};//这个数组是用来保存各个形状高度的class Box//俄罗斯方块类
{private:int map[23][12];//画面坐标int hotpoint[2];//热点(即当前活动的点,所有图形都是相当此点绘制的)int top;//当前最高位置int point;//分数int level;//等级int ID;//当前活动图形的ID号public:Box()//初始化{int i,j;for(i=0;i<23;i++)for(j=0;j<12;j++)map[i][j]=0;hotpoint[0]=0;hotpoint[1]=5;point=0;level=1;top=99;ID=0;}void DrawMap();//画界面int Judge(int x,int y);//判断当前位置能否绘制图形void Welcome();//欢迎界面void DrawBox(int x,int y,int num);//绘制图形void Redraw(int x,int y,int num);//擦除图形void Run();//运行void Turn();//转动方块void UpdataMap();//更新画面
};void Box::DrawMap()//画界面
{int i;for(i=0;i<14;i++){SetPos(i*2,0);cout<<"■";}for(i=1;i<=24;i++){SetPos(0,i);cout<<"■";SetPos(13*2,i);cout<<"■";}for(i=0;i<14;i++){SetPos(i*2,24);cout<<"■";}i=15;for(i=15;i<=25;i++){SetPos(i*2,0);cout<<"■";}for(i=1;i<=8;i++){SetPos(15*2,i);cout<<"■";SetPos(25*2,i);cout<<"■";}for(i=15;i<=25;i++){SetPos(i*2,9);cout<<"■";}SetPos(16*2,16);cout<<"俄罗斯方块";SetPos(16*2,17);cout<<"分数:"<<point;SetPos(16*2,18);cout<<"等级:"<<level;
}void Box::DrawBox(int x,int y,int num)//绘制图形
{int i;int nx,ny;for(i=0;i<4;i++){nx=x+sharp[num][i*2];ny=y+sharp[num][i*2+1];SetPos((ny+1)*2,nx+1);//利用sharp数组相对于点x,y绘制形状cout<<"■";}
}void Box::Redraw(int x,int y,int num)//擦除图形,原理同上
{int i;int nx,ny;for(i=0;i<4;i++){nx=x+sharp[num][i*2];ny=y+sharp[num][i*2+1];SetPos((ny+1)*2,nx+1);cout<<" ";}
}void Box::Turn()//转动图形,单纯的该ID而已
{switch(ID){case A1: ID=A2; break;case A2: ID=A1; break;case B: ID=B; break;case C11: ID=C12; break;case C12: ID=C13; break;case C13: ID=C14; break;case C14: ID=C11; break;case C21: ID=C22; break;case C22: ID=C23; break;case C23: ID=C24; break;case C24: ID=C21; break;case D11: ID=D12; break;case D12: ID=D11; break;case D21: ID=D22; break;case D22: ID=D21; break;}}void Box::Welcome()//欢迎界面
{char x;while(1){system("cls");cout<<"■■■■■■■■■■■■■■■■■■■"<<endl;cout<<"■    俄罗斯方块控制台版(不闪屏)  ■"<<endl;cout<<"■■■■■■■■■■■■■■■■■■■"<<endl;cout<<"■     A,D左右移动  S向下加速       ■"<<endl;cout<<"■        空格键转动方块            ■"<<endl;cout<<"■■■■■■■■■■■■■■■■■■■"<<endl;cout<<"■                                  ■"<<endl;cout<<"■           测试版                 ■"<<endl;cout<<"■                                  ■"<<endl;cout<<"■        按1-9选择等级!!         ■"<<endl;cout<<"■                                  ■"<<endl;cout<<"■                                  ■"<<endl;cout<<"■■■■■■■■■■■■■■■■■■■"<<endl;SetPos(8,10);x=getch();if(x<='9'&&x>='1')//设置等级{level=x-'0';break;}}
}void Box::UpdataMap()//更新画面(关键)
{int clear;int i,j,k;int nx,ny;int flag;for(i=0;i<4;i++)//更新map数组的信息{nx=hotpoint[0]+sharp[ID][i*2];ny=hotpoint[1]+sharp[ID][i*2+1];map[nx][ny]=1;}if(hotpoint[0]<top)//如果热点高于顶点则更新顶点top=hotpoint[0];clear=0;//消除的格数for(i=hotpoint[0];i<hotpoint[0]+high[ID];i++){flag=0;for(j=0;j<12;j++)//检测是否可以消除此行{if(map[i][j]==0){flag=1;break;}}if(flag==0)//可以消除{for(k=i;k>=top;k--)//从当前位置向上所有的点下移一行{if(k==0)//最高点特殊处理for(j=0;j<12;j++){map[k][j]=0;SetPos((j+1)*2,k+1);cout<<" ";}else{for(j=0;j<12;j++){map[k][j]=map[k-1][j];SetPos((j+1)*2,k+1);if(map[k][j]==0)cout<<" ";elsecout<<"■";}}}top++;//消除成功,最高点下移clear++;point+=clear*100;}}SetPos(16*2,17);cout<<"分数:"<<point;
}void Box::Run()//运行游戏
{int i=0;char x;int Count;//计数器int tempID;int temp;srand((int)time(0));ID=rand()%15;//随机生成ID和下一个IDtempID=rand()%15;DrawBox(hotpoint[0],hotpoint[1],ID);//绘制图形DrawBox(3,17,tempID);Count=1000-level*100;//等级决定计数while(1){if(i>=Count)//时间到{i=0;//计数器清零if(Judge(hotpoint[0]+1,hotpoint[1]))//如果下个位置无效(即到底){UpdataMap();//更新画面ID=tempID;//生成新ID,用原等待ID替换为当前IDhotpoint[0]=0;//热点更新hotpoint[1]=5;Redraw(3,17,tempID);tempID=rand()%15;DrawBox(hotpoint[0],hotpoint[1],ID);DrawBox(3,17,tempID);if(Judge(hotpoint[0],hotpoint[1]))//无法绘制开始图形,游戏结束{system("cls");SetPos(25,15);cout<<"游戏结束!!!最终得分为:"<<point<<endl;system("pause");exit(0);}}else{Redraw(hotpoint[0],hotpoint[1],ID);//没有到底,方块下移一位hotpoint[0]++;//热点下移DrawBox(hotpoint[0],hotpoint[1],ID);}}if(kbhit())//读取键盘信息{x=getch();if(x=='a'||x=='A')//左移{if(Judge(hotpoint[0],hotpoint[1]-1)==0){Redraw(hotpoint[0],hotpoint[1],ID);hotpoint[1]-=1;DrawBox(hotpoint[0],hotpoint[1],ID);}}if(x=='d'||x=='D')//右移{if(Judge(hotpoint[0],hotpoint[1]+1)==0){Redraw(hotpoint[0],hotpoint[1],ID);hotpoint[1]+=1;DrawBox(hotpoint[0],hotpoint[1],ID);}}if(x=='s'||x=='S')//向下加速{if(Judge(hotpoint[0]+1,hotpoint[1])==0){Redraw(hotpoint[0],hotpoint[1],ID);hotpoint[0]+=1;DrawBox(hotpoint[0],hotpoint[1],ID);}}if(x==' ')//转动方块{temp=ID;Turn();if(Judge(hotpoint[0],hotpoint[1])==0){Redraw(hotpoint[0],hotpoint[1],temp);DrawBox(hotpoint[0],hotpoint[1],ID);}elseID=temp;}while(kbhit())//读掉剩下的键盘信息getch();}Sleep(1);//等待1毫秒i++;//计数器加1}
}int Box::Judge(int x,int y)//判断当前是否可以绘制方块
{int i;int nx,ny;for(i=0;i<4;i++){nx=x+sharp[ID][i*2];ny=y+sharp[ID][i*2+1];if(nx<0||nx>=23||ny<0||ny>=12||map[nx][ny]==1)//不能,返回1return 1;}return 0;
}int main()//主函数
{Box game;game.Welcome();system("cls");game.DrawMap();game.Run();system("pause");
}

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/444034.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

leetcode445. 两数相加 II

给你两个 非空 链表来代表两个非负整数。数字最高位位于链表开始位置。它们的每个节点只存储一位数字。将这两数相加会返回一个新的链表。 你可以假设除了数字 0 之外&#xff0c;这两个数字都不会以零开头。 进阶&#xff1a; 如果输入链表不能修改该如何处理&#xff1f;换…

Java中如何实现每天定时对数据库的操作

现在有一个很棘手的问题&#xff1a;客户要赠加一个功能&#xff0c;就是每天晚上11点要统计一下数据&#xff0c;并存到一个文件中&#xff0c;我试着用线程&#xff0c;但是总达不到理想的效果。请给点思路&#xff0c;多谢了。 我们的开发环境是tomcat和servlet&#xff0c;…

leetcode面试题 02.08. 环路检测

给定一个有环链表&#xff0c;实现一个算法返回环路的开头节点。 有环链表的定义&#xff1a;在链表中某个节点的next元素指向在它前面出现过的节点&#xff0c;则表明该链表存在环路。 示例 1&#xff1a; 输入&#xff1a;head [3,2,0,-4], pos 1 输出&#xff1a;tail co…

leetcode485. 最大连续1的个数 *py:“又是一行就解决了,没意思”

给定一个二进制数组&#xff0c; 计算其中最大连续1的个数。 示例 1: 输入: [1,1,0,1,1,1] 输出: 3 解释: 开头的两位和最后的三位都是连续1&#xff0c;所以最大连续1的个数是 3. 注意&#xff1a; 输入的数组只包含 0 和1。 输入数组的长度是正整数&#xff0c;且不超过 1…

leetcode645. 错误的集合

645. 错误的集合 难度简单98 集合 S 包含从1到 n 的整数。不幸的是&#xff0c;因为数据错误&#xff0c;导致集合里面某一个元素复制了成了集合里面的另外一个元素的值&#xff0c;导致集合丢失了一个整数并且有一个元素重复。 给定一个数组 nums 代表了集合 S 发生错误后的…

一篇文章揭穿创业公司的套路

初衷 每个初入社会的求职者&#xff0c;都曾经有过找工作被坑的经历。总结了以下潜台词&#xff0c;如果你能全部GET到&#xff0c;那么恭喜你&#xff0c;已被老板们拉入黑名单。 核心 「工资4k - 8k」——那工资就是4k 「工资上不封顶」——就是说说而已&#xff0c;没人会给…

java获取IP地址:

public class IPDemo {public static void main(String [] args) throws UnknownHostException{//获取本地主机InetAddress localHost InetAddress.getLocalHost();System.out.println(localHost);//Lenovo-sxg/192.168.1.106//获取本地主机的IP地址String ipaddress localHo…

《三天给你聊清楚redis》第1天先唠唠redis是个啥(18629字)

后端需要知道的关于redis的事&#xff0c;基本都在这里了。 此文后续会改为粉丝可见&#xff0c;所以喜欢的请提前关注。 你的点赞和评论是我创作的最大动力&#xff0c;谢谢。 1、入门 Redis是一款基于键值对的NoSQL数据库&#xff0c;它的值支持多种数据结构&#xff1a;…

获取IP地址:

public class IPDemo {public static void main(String [] args) throws UnknownHostException{//获取本地主机InetAddress localHost InetAddress.getLocalHost();System.out.println(localHost);//Lenovo-sxg/192.168.1.106//获取本地主机的IP地址String ipaddress localHo…

使用github+jsdelivr作为视频床

感谢JefferyIF大佬提供的神奇方法。 1. 配置FFmpeg 注&#xff1a;IOS因为不支持HLS&#xff0c;所以对IOS上无法正常播放视频&#xff0c;其他端都可以正常播放。 因为脚本要使用到FFmeg对源视频文件切分成m3u8格式&#xff0c;所以在使用脚本之前&#xff0c;请配置好 FFm…

使用PicGo+github+jsdelivr作为图床

1.什么是图床&#xff1f; 所谓图床工具&#xff0c;就是自动把本地图片转换成链接的一款工具&#xff0c;网络上有很多图床工具&#xff0c;就目前使用种类而言&#xff0c;PicGo 算得上一款比较优秀的图床工具。它是一款用 Electron-vue 开发的软件&#xff0c;可以支持微博…

万字干货:教新手从0到1搭建完整的增长数据体系

在实际的业务中&#xff0c;大多数人可能只会遇到以下一种或几种常见的场景&#xff0c;并且对于各个细分场景&#xff0c;所需要解决的问题和关注重点都是不一样的。 场景一&#xff1a;你刚加入一个成熟产品的用户增长部门&#xff0c;会发现业务当前有非常全面详实的用户和业…

《三天给你聊清楚redis》第2天看看redis怎么被搞出来的(22036字)

后端需要知道的关于redis的事&#xff0c;基本都在这里了。 此文后续会改为粉丝可见&#xff0c;所以喜欢的请提前关注。 你的点赞和评论是我创作的最大动力&#xff0c;谢谢。 3、单机实现 3.1、数据库概述 redis服务器将所有数据库都保存在redis/redisServer中&#xff…

JAVA中对象的序列化的作用?

1、序列化是干什么的&#xff1f; 简单说就是为了保存在内存中的各种对象的状态&#xff0c;并且可以把保存的对象状态再读出来。虽然你可以用你自己的各种各样的方法来保存Object States&#xff0c;但是Java给你提供一种应该比你自己好的保存对象状态的机制,那就是序列化。 2…

leetcode559. N叉树的最大深度

给定一个 N 叉树&#xff0c;找到其最大深度。 最大深度是指从根节点到最远叶子节点的最长路径上的节点总数。 例如&#xff0c;给定一个 3叉树 : 我们应返回其最大深度&#xff0c;3。 说明: 树的深度不会超过 1000。 树的节点总不会超过 5000。 思路见代码 /* // De…

leetcode1491. 工资平均值 这也叫题?也太简单了吧

给你一个整数数组 salary &#xff0c;数组里每个数都是 唯一 的&#xff0c;其中 salary[i] 是第 i 个员工的工资。 请你返回去掉最低工资和最高工资以后&#xff0c;剩下员工工资的平均值。 示例 1&#xff1a; 输入&#xff1a;salary [4000,3000,1000,2000] 输出&#x…

leetcode1207. 独一无二的出现次数

给你一个整数数组 arr&#xff0c;请你帮忙统计数组中每个数的出现次数。 如果每个数的出现次数都是独一无二的&#xff0c;就返回 true&#xff1b;否则返回 false。 示例 1&#xff1a; 输入&#xff1a;arr [1,2,2,1,1,3] 输出&#xff1a;true 解释&#xff1a;在该数组…

leetcode1085. 最小元素各数位之和 py不止是字符串的神!

给你一个正整数的数组 A。 然后计算 S&#xff0c;使其等于数组 A 当中最小的那个元素各个数位上数字之和。 最后&#xff0c;假如 S 所得计算结果是 奇数 的请你返回 0&#xff0c;否则请返回 1。 示例 1: 输入&#xff1a;[34,23,1,24,75,33,54,8] 输出&#xff1a;0 解释…

leetcode709. 转换成小写字母 最秀狼人做法(比狠多一点)

实现函数 ToLowerCase()&#xff0c;该函数接收一个字符串参数 str&#xff0c;并将该字符串中的大写字母转换成小写字母&#xff0c;之后返回新的字符串。 示例 1&#xff1a; 输入: "Hello" 输出: "hello" 示例 2&#xff1a; 输入: "here"…

leetcode1299. 将每个元素替换为右侧最大元素

给你一个数组 arr &#xff0c;请你将每个元素用它右边最大的元素替换&#xff0c;如果是最后一个元素&#xff0c;用 -1 替换。 完成所有替换操作后&#xff0c;请你返回这个数组。 示例&#xff1a; 输入&#xff1a;arr [17,18,5,4,6,1] 输出&#xff1a;[18,6,6,6,1,-1]…