学习笔记10-C语言-小项目-五子棋

小项目:

需要的数据
1、定义棋盘的二维数组
2、定义变量用于记录下棋的坐标
3、定义角色 @ 黑棋 O 白棋 * 空位业务逻辑:
是否需要对数据初始化
for(;;)
{1、清屏、显示棋盘2、落子坐标是否合法、该位置是否有棋子3、判断是否五子连珠4、交换角色5、显示棋盘
}

代码1

#include<stdio.h>
#include<getch.h>
#include<stdlib.h>
int map[15][15]={};
int bx=0,by=0;
int cnt=1,ret=0;int if_end(void);
int color(void);void init(void)
{map[bx][by]=3;	
}void show(void)
{system("clear");for(int i=0;i<15;i++){for(int j=0;j<15;j++){switch(map[i][j]){case 0:printf("* ");break;	case 1:printf("@ ");break;	case 2:printf("O ");break;	default:printf("# ");break;}}printf("\n");}printf("棋手1: @   棋手2: O\n");printf("当前棋手:%d\n",color());
}void move_left(void)
{if(by-1>=0){map[bx][by] -=3;map[bx][by-1] +=3;by--;}
}void move_right(void)
{if(by+1<15){map[bx][by] -=3;map[bx][by+1] +=3;by++;}
}void move_up(void)
{if(bx-1>=0){map[bx][by] -=3;map[bx-1][by] +=3;bx--;}
}void move_down(void)
{if(bx+1<15){map[bx][by] -=3;map[bx+1][by] +=3;bx++;}
}void drop()
{if(map[bx][by]==3){map[bx][by] += color();cnt++;}
}void move(void)
{switch(getch()){case 183:move_up();break;case 184:move_down();break;case 186:move_left();break;case 185:move_right();break;case 48:drop();break;}
}int color(void)
{if(cnt%2){return 1;}return 2;
}int check1(void)
{int num=0;for(int i=0;i<15;i++){if(map[bx][i]==1 || map [bx][i]==4){num++;if(num==5)return 1;}else{num=0;}}for(int i=0;i<15;i++){if(map[bx][i]==2 || map [bx][i]==5){num++;if(num==5)return 1;}else{num=0;}}return 0;
}int check2(void)
{int num=0;for(int i=0;i<15;i++){if(map[i][by]==1 || map [i][by]==4){num++;if(num==5)return 1;}else{num=0;}}for(int i=0;i<15;i++){if(map[i][by]==2 || map [i][by]==5){num++;if(num==5)return 1;}else{num=0;}}return 0;
}int check3(void)
{int i=1,num=0;while(by+i<15 && bx+i<15){if(map[bx][by]-3 != 0 && map[bx+i][by+i]==map[bx][by]-3){num++;i++;}else{i=1;break;}}while(by-i>=0 && bx-i>=0){if(map[bx][by]-3 != 0 && map[bx-i][by-i]==map[bx][by]-3){num++;i++;}else{i=1;break;}}if(num>=4)return 1;return 0;
}int check4(void)
{int i=1,num=0;while(by+i<15 && bx-i>=0){if(map[bx][by]-3 != 0 && map[bx-i][by+i]==map[bx][by]-3){num++;i++;}else{i=1;break;}}while(by-i>=0 && bx+i<15){if(map[bx][by]-3 != 0 && map[bx+i][by-i]==map[bx][by]-3){num++;i++;}else{i=1;break;}}if(num>=4)return 1;return 0;
}int is_end(void)
{if(check1()==1)	return 1;if(check2()==1)	return 1;if(check3()==1)	return 1;if(check4()==1)	return 1;return 0;
}int main(int argc,const char* argv[])
{init();while(1){show();if(is_end()==1){map[bx][by] -=3;show();break;}move();}if(cnt%2){printf("白棋win");}else{printf("黑棋win");	}
}

代码2:光标代替字符#

#include<stdio.h>
#include<getch.h>
#include<stdlib.h>
int map[15][15]={};
int bx=7,by=7;
int cnt=1,ret=0;int if_end(void);
int color(void);void show(void)
{system("clear");for(int i=0;i<15;i++){for(int j=0;j<15;j++){switch(map[i][j]){case 0:printf(" *");break;	case 1:printf(" @");break;	case 2:printf(" O");break;	}}printf("\n");}printf("棋手1: @   棋手2: O\n");printf("当前棋手:%d\n",color());
}void drop()
{if(map[bx][by]==0){map[bx][by] += color();cnt++;}
}void move(void)
{printf("\33[%d;%dH",bx+1,(by+1)*2);switch(getch()){case 183:bx>0&& bx--;break;case 184:bx<14&& bx++;break;case 186:by>0&& by--;break;case 185:by<14&& by++;break;case 48:drop();break;}
}int color(void)
{if(cnt%2){return 1;}return 2;
}int check1(void)
{int num=0;for(int i=0;i<15;i++){if(map[bx][i]==1 || map [bx][i]==4){num++;if(num==5)return 1;}else{num=0;}}for(int i=0;i<15;i++){if(map[bx][i]==2 || map[bx][i]==5){num++;if(num==5)return 1;}else{num=0;}}return 0;
}int check2(void)
{int num=0;for(int i=0;i<15;i++){if(map[i][by]==1 || map [i][by]==4){num++;if(num==5)return 1;}else{num=0;}}for(int i=0;i<15;i++){if(map[i][by]==2 || map [i][by]==5){num++;if(num==5)return 1;}else{num=0;}}return 0;
}int check3(void)
{int i=1,num=0;while(by+i<15 && bx+i<15){if(map[bx][by] != 0 && map[bx+i][by+i]==map[bx][by]){num++;i++;}else{i=1;break;}}while(by-i>=0 && bx-i>=0){if(map[bx][by] != 0 && map[bx-i][by-i]==map[bx][by]){num++;i++;}else{i=1;break;}}if(num>=4)return 1;return 0;
}int check4(void)
{int i=1,num=0;while(by+i<15 && bx-i>=0){if(map[bx][by] != 0 && map[bx-i][by+i]==map[bx][by]){num++;i++;}else{i=1;break;}}while(by-i>=0 && bx+i<15){if(map[bx][by] != 0 && map[bx+i][by-i]==map[bx][by]){num++;i++;}else{i=1;break;}}if(num>=4)return 1;return 0;
}int is_end(void)
{if(check1()==1)	return 1;if(check2()==1)	return 1;if(check3()==1)	return 1;if(check4()==1)	return 1;return 0;
}int main(int argc,const char* argv[])
{while(1){show();if(is_end()==1){}move();}if(cnt%2){printf("白棋win");}else{printf("黑棋win");	}
}

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

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

相关文章

学习笔记11-C语言-指针

什么是指针&#xff1a; 指针是一种特护的数据类型&#xff0c;使用它可以定义指针变量&#xff0c;指针变量存储的是整型数据&#xff0c;代表内存的编号&#xff0c;通过这个编号可以访问到对应内存。为什么使用指针 1、函数与函数之间是相互独立的&#xff0c;但是有些时候…

学习笔记12-C语言-堆内存、字符串

什么是堆内存&#xff1a; 是进程中的一个内存段&#xff08;text\data\bss\heap\stack&#xff09;&#xff0c;由程序猿手动控制。 特点是足够大&#xff0c;缺点是使用麻烦为什么要使用堆内存&#xff1a; 1、随着程序的复杂&#xff0c;数据会越来越多。 2、其他的内存段…

学习笔记13-C语言-字符串函数、缓冲区

字符串的常用函数: #include<string.h> size_t strlen(const char* s); 功能&#xff1a;计算字符串长度&#xff0c;但是结果不包括\0 返回值&#xff1a;返回字符串中字符的个数size_t str_len(const char* str) {assert(NULL ! str);const char* tmp str;while(*tmp…

Oracle数据库里面查询字符串类型的字段不为空和为空的SQL语句:

摘要&#xff1a;近期项目中&#xff0c;在做高级查询的时候有个条件是根据选择的字段&#xff0c;然后再选择字段的值为空和不为空做查询&#xff0c;在写SQL语句的时候费了很长时间&#xff0c;现在记录一下&#xff0c;方便日后查看&#xff1a; 一&#xff1a;查询字符串类…

学习笔记14-C语言-小项目-通讯录

通讯录&#xff1a; 要求&#xff1a; 姓名&#xff0c;性别、电话&#xff0c;最多储存50个联系人 功能&#xff1a;1、添加联系人2、按名字删除联系人3、按姓名修改联系人信息4、查找联系人&#xff0c;可通过电话&#xff0c;名字查找&#xff0c;支持模糊查找5、显示所有联…

学习笔记15-C语言-预处理指令、条件编译、头文件

预处理指令&#xff1a; 程序猿编写的代码不是标准C代码&#xff0c;并不能被真正的编译器索编译&#xff0c;需要一段程序把代码翻译一下。 翻译的过程叫做预处理&#xff0c;被翻译的代码叫做预处理指令&#xff0c;以#开头的都是预处理指令查看预处理的过程&#xff1a;gcc…

学习笔记16-C语言-小项目-使用Makefile完成2048

Makefile: Makefile是一系列编译指令组成的可执行文本&#xff0c;也叫做编译脚本。 在终端执行make命令会自动执行Makefile脚本中的编译命令&#xff0c; 而且它还可以根据文件的最后修改时间来判断哪些文件是否需要重新编译、哪些文件不需要重新编译&#xff0c;从而大大提高…

学习笔记17-C语言-结构、联合、枚举

结构&#xff1a; struct 结构是由程序猿自己设计的一种数据类型&#xff0c;用于描述一个事务的各项数据&#xff0c;由若干个不同的基础数据类型组成。设计结构&#xff1a;struct 结构体名{类型 成员名&#xff1b;...}&#xff1b;定义结构体变量struct 结构体名 变量名&a…

Maven 3.0.5 安装和配置:

摘要&#xff1a;现在的Web项目越来越多的都用maven管理了&#xff0c;所以我也抽时间学习学习&#xff0c;为了赶上时代&#xff01; 一&#xff1a;首先到maven官网&#xff1a;http://maven.apache.org/&#xff0c;然后选择相应的版本下载&#xff0c;我这里下载的是maven…

学习笔记18-C语言-文件

文件的分类&#xff1a; 文本文件&#xff1a; 存储的是ASCII码值的二进制 二进制文件&#xff1a; 存储的是数据的补码文件IO&#xff1a; FILE *fopen(const char *path, const char *mode); 功能&#xff1a;打开或者创建文件 path&#xff1a;文件的路径 mode&#x…

使用INNER JOIN ON 多表关联查询,获取指定用户下指定权限的资源SQL:

摘要&#xff1a;最近在看一个开源框架&#xff0c;其中用户&#xff0c;角色&#xff0c;资源&#xff0c;这块我感觉比较重要&#xff0c;所以就自己也模仿着写了下&#xff0c;其中在获取指定用户下的权限资源的时候遇到问题了&#xff0c;开始时&#xff0c;我首先想到的方…

Maven学习记录之maven基本操作命令,maven本地工厂的创建,maven骨架的生成,以及在eclipse中创建maven工程:...

摘要&#xff1a;今天又学习了一下maven&#xff0c;之前是下载并安装和配置好了maven的环境&#xff0c;今天主要学习的内容包括&#xff1a;maven本地工厂的创建&#xff0c;maven骨架的生成命令&#xff0c;maven在dos下创建maven工程&#xff0c;以及在eclipse中创建mavne工…

Oracle中通过游标执行带参数的存储过程实现解析CLOB字段内的xml字符串:

摘要&#xff1a;近来之前的项目数据出现了问题&#xff0c;原因是由于之前在设计数据库的时候把时间字段设置成了字符串格式&#xff0c;所以给后期的数据操作带来了很大的麻烦&#xff0c;这里提醒一下各位程序猿&#xff0c;以后在开发项目的时候时间字段一定要是时间字段&a…

Eclipse中使用Checkstyle,checkstyle插件检查java代码的自定义配置文件:

摘要&#xff1a;近来项目组在搞代码检查&#xff0c;所以领导让把checkstyle这个插件搞明白&#xff0c;现在我把我们写的自定义的checkstyle.xml文件记录一下&#xff0c;以便大家可以一起使用&#xff1a; 一&#xff1a;要使用checkstyle插件在eclipse中检查java代码&…

Linux 下安装 jdk-7u75-linux-x64.gz,jdk1.7.0_75,jdk1.7步骤:

摘要&#xff1a;近来又用到了Linux系统&#xff0c;所以就又新装了一个虚拟机和CentOS 6.4来用&#xff0c;搞开发的程序猿们可能都知道&#xff0c;在现在的很多企业中&#xff0c;生产环境大多都是Linux服务器&#xff0c;并且用的比较多的大都是CentOS&#xff0c;Red hat系…

Win7+VMware10.0+CentOS 6.4+Tomcat,Win7访问不了CentOS6.4上的Tomcat

摘要&#xff1a;今天在linux下安装Tomcat后&#xff0c;在虚拟机本地通过:http://localhost:8080/可以访问安装好的Tomcat服务器&#xff0c;但是在本机就不能访问&#xff0c;前提是在本机下可以ping的通虚拟机的IP地址的&#xff0c;最后经过Google&#xff0c;发现说可能是…

Linux下配置OpenLDAP服务记录

摘要&#xff1a;最近部门需要整合所有的系统&#xff0c;所以领导说要通过OpenLdap数据库来实现对所有系统的统一管理&#xff0c;所以需要在服务器上配置一下LDAP服务&#xff0c;我们这里选择的是OpenLdap服务&#xff0c;我在网上搜索了很多&#xff0c;开始都没有配置成功…

Linux下配置CollabNet Subversion Edge

摘要&#xff1a;最近一直都在搞一下管理员的工作&#xff0c;今天又搞了svn的管理工具CollabNetSubversionEdge&#xff0c;网上也有很多例子&#xff0c;但是很多都是可以访问到web界面&#xff0c;但是不能启动版本库的服务&#xff0c;所以我经过多次尝试&#xff0c;终于解…

养成让自己进步的10个习惯

养成让自己进步的10个习惯 1.永远不说不可能。"办法总比问题多" 2.凡事第一反应找方法&#xff0c;不是找借口。"不要推卸责任" 3.养成记录习惯&#xff0c;不太依赖脑袋。"好记性不如烂笔头" 4.每天出门照镜子&#xff0c;给自己自信的微笑。&…

Oracle存储过程中使用游标来批量解析CLOB字段里面的xml字符串:

摘要&#xff1a;之前在项目中使用到了Oracle数据库中通过触发器去调用存储过程执行数据解析并Update到对应的数据表中&#xff0c;但是&#xff0c;经过一段时间的测试使用发现&#xff0c;如果job那天停掉了&#xff0c;然后你再重新新建job的话&#xff0c;这时候可能会有很…