c语言五子棋利用坐标下棋,基于C语言实现五子棋游戏

2023-10-30 15:59

本文主要是介绍c语言五子棋利用坐标下棋,基于C语言实现五子棋游戏,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

采用二维数组制作五子棋,用坐标下棋。

请看代码。

8fe1e4aa6e300b235b8c8a4b29936281.png

include

#include

#include

#include

#include

#include

void menu()//目录

{

char xuanze = 0,xuanze2;

printf("\n");

printf("\n");

printf(" #############################################\n");

printf(" *五子棋小游戏*\n");

printf(" *1.双人游戏*\n");

printf(" *2.人机对战(暂未开放)\n");

printf(" *3.游戏须知\n");

printf(" #############################################\n");

printf(" 请选择选项,目前仅有 1 选项\n");

printf("\n");

printf(" ");

xuanze = _getch();

switch (xuanze)

{

case 1:

break;

case 3:

printf("本游戏是键盘输入坐标来落子的,白棋先落,第二次落子为黑色,依次落子。\n");

printf("若落子坐标非法则需重新落子。\n");

printf("键盘输入1直接进入游戏\n");

}

}

int t = 2;

int pan[20][20] =

{

{1,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,3},

{4,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,6},

{4,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,6},

{4,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,6},

{4,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,6},

{4,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,6},

{4,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,6},

{4,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,6},

{4,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,6},

{4,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,6},

{4,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,6},

{4,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,6},

{4,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,6},

{4,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,6},

{4,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,6},

{4,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,6},

{4,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,6},

{4,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,6},

{4,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,6},

{7,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,9}

};

void qp()//棋盘

{

int i, j, k = 0;

printf(" ");

for (i = 0; i < 10; i++)

printf(" %d", i + 1);

for (i = 10; i < 20; i++)

printf("%d", i + 1);

printf("\n");

printf("1 ");

//printf("┌ ┬ ┐├ ┼ ┤└ ┴ ┘│ ");©○●┼

for (i = 0; i < 20; i++)

for (j = 0; j < 20; j++)

{

switch (pan[i][j])

{

case 1:

printf("┌ ");

k++;

if (k % 20 == 0)

{

printf("\n");

}

break;

case 2:

printf("┬ ");

k++;

if (k % 20 == 0)

printf("\n");

break;

case 3:

printf("┐ ");

k++;

if (k % 20 == 0)

{

printf("%d", i+1);

printf("\n");

printf("%d ", i + 1);

}

break;

case 4:

printf("├ ");

k++;

if (k % 20 == 0)

printf("\n");

break;

case 5:

printf("┼ ");

k++;

if (k % 20 == 0)

printf("\n");

break;

case 6:

printf("┤ ");

k++;

if (k % 20 == 0)

{

printf("%d", i+1);

printf("\n");

if(i<8)

printf("%d ", i + 2);

if(i>7)

printf("%d", i + 2);

}

break;

case 7:

printf("└ ");

k++;

if (k % 20 == 0)

printf("\n");

break;

case 8:

printf("┴ ");

k++;

if (k % 20 == 0)

printf("\n");

break;

case 9:

printf("┘ ");

k++;

if (k % 20 == 0)

{

printf("%d", i + 1);

printf("\n");

}

break;

case 10:

printf("○");

k++;

if (k % 20 == 0)

{

printf("%d", i+1);

printf("\n");

}

break;

case 11:

printf("●");

k++;

if (k % 20 == 0)

{

printf("%d", i+1);

printf("\n");

}

break;

}

}

printf(" ");

for (i = 0; i < 10; i++)

printf(" %d", i + 1);

for (i = 10; i < 20; i++)

printf("%d", i + 1);

printf("\n");

printf("\n");

}

void play()

{

int i, j;

while (1)

{

printf("*请选择落子坐标(x,y): ");

scanf_s("%d %d", &j, &i);

printf("\n");

if(i>0&&i<21&&j>0&&j<21)

{

if (pan[i - 1][j - 1] != 10 && pan[i - 1][j - 1] != 11)

{

if (t % 2 == 1)

{

t++;

pan[i - 1][j - 1] = 11;

break;

}

else if (t % 2 == 0)

{

t++;

pan[i - 1][j - 1] = 10;

break;

}

}

else if (pan[i-1][j-1] == 10 || pan[i-1][j-1] == 11)

{

printf("此处已经有棋子,请重新输入\n");

continue;

}

}

else if (i < 1 || i > 21 || j < 1 || j > 21)

{

printf("坐标不合法,请重新输入\n");

continue;

}

}

}

void test()

{

int i, j;

for(i=0;i<20;i++)

for (j = 0; j < 20; j++)

{

if (pan[i][j] != 1 || 2 || 3 || 4 || 5 || 6 || 7 || 8 || 9)

{

if (pan[i][j] == pan[i][j + 1]&&pan[i][j] == pan[i][j + 2]&&pan[i][j] == pan[i][j + 3]&&pan[i][j] == pan[i][j + 4])

{

if (pan[i][j] == 11)

{

printf("白棋获胜\n");

}

if (pan[i][j] == 10)

{

printf("黑棋获胜\n");

}

}

if (pan[i][j] == pan[i + 1][j]&&pan[i][j] == pan[i + 2][j]&&pan[i][j] == pan[i + 3][j]&&pan[i][j] == pan[i + 4][j])

{

if (pan[i][j] == 11)

{

printf("白棋获胜\n");

}

if (pan[i][j] == 10)

{

printf("黑棋获胜\n");

}

}

if (pan[i][j] == pan[i + 1][j + 1]&&pan[i][j] == pan[i + 2][j + 2]&&pan[i][j] == pan[i + 3][j + 3] &&pan[i][j]== pan[i + 4][j + 4])

{

if (pan[i][j] == 11)

{

printf("白棋获胜\n");

}

if (pan[i][j] == 10)

{

printf("黑棋获胜\n");

}

}

if (pan[i][j] == pan[i - 1][j + 1]&&pan[i][j] == pan[i - 2][j + 2] &&pan[i][j]== pan[i - 3][j + 3]&&pan[i][j] == pan[i - 4][j + 4])

{

if (pan[i][j] == 11)

{

printf("白棋获胜\n");

}

if (pan[i][j] == 10)

{

printf("黑棋获胜\n");

}

}

}

}

}

int main()

{

system("mode con cols=98 lines=48");

SetConsoleTitleA("五子棋小游戏"); //设置窗口

menu();

system("cls");

while (1)

{

qp();

test();

play();

system("cls");

}

system("pause");

return 0;

}

更多有趣的经典小游戏实现专题,分享给大家:

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

这篇关于c语言五子棋利用坐标下棋,基于C语言实现五子棋游戏的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/309019

相关文章

SpringBoot路径映射配置的实现步骤

《SpringBoot路径映射配置的实现步骤》本文介绍了如何在SpringBoot项目中配置路径映射,使得除static目录外的资源可被访问,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一... 目录SpringBoot路径映射补:springboot 配置虚拟路径映射 @RequestMapp

Python与MySQL实现数据库实时同步的详细步骤

《Python与MySQL实现数据库实时同步的详细步骤》在日常开发中,数据同步是一项常见的需求,本篇文章将使用Python和MySQL来实现数据库实时同步,我们将围绕数据变更捕获、数据处理和数据写入这... 目录前言摘要概述:数据同步方案1. 基本思路2. mysql Binlog 简介实现步骤与代码示例1

Redis实现高效内存管理的示例代码

《Redis实现高效内存管理的示例代码》Redis内存管理是其核心功能之一,为了高效地利用内存,Redis采用了多种技术和策略,如优化的数据结构、内存分配策略、内存回收、数据压缩等,下面就来详细的介绍... 目录1. 内存分配策略jemalloc 的使用2. 数据压缩和编码ziplist示例代码3. 优化的

基于C#实现PDF转图片的详细教程

《基于C#实现PDF转图片的详细教程》在数字化办公场景中,PDF文件的可视化处理需求日益增长,本文将围绕Spire.PDFfor.NET这一工具,详解如何通过C#将PDF转换为JPG、PNG等主流图片... 目录引言一、组件部署二、快速入门:PDF 转图片的核心 C# 代码三、分辨率设置 - 清晰度的决定因

Java Kafka消费者实现过程

《JavaKafka消费者实现过程》Kafka消费者通过KafkaConsumer类实现,核心机制包括偏移量管理、消费者组协调、批量拉取消息及多线程处理,手动提交offset确保数据可靠性,自动提交... 目录基础KafkaConsumer类分析关键代码与核心算法2.1 订阅与分区分配2.2 拉取消息2.3

SpringBoot集成XXL-JOB实现任务管理全流程

《SpringBoot集成XXL-JOB实现任务管理全流程》XXL-JOB是一款轻量级分布式任务调度平台,功能丰富、界面简洁、易于扩展,本文介绍如何通过SpringBoot项目,使用RestTempl... 目录一、前言二、项目结构简述三、Maven 依赖四、Controller 代码详解五、Service

Python 基于http.server模块实现简单http服务的代码举例

《Python基于http.server模块实现简单http服务的代码举例》Pythonhttp.server模块通过继承BaseHTTPRequestHandler处理HTTP请求,使用Threa... 目录测试环境代码实现相关介绍模块简介类及相关函数简介参考链接测试环境win11专业版python

GO语言短变量声明的实现示例

《GO语言短变量声明的实现示例》在Go语言中,短变量声明是一种简洁的变量声明方式,使用:=运算符,可以自动推断变量类型,下面就来具体介绍一下如何使用,感兴趣的可以了解一下... 目录基本语法功能特点与var的区别适用场景注意事项基本语法variableName := value功能特点1、自动类型推

GO语言中函数命名返回值的使用

《GO语言中函数命名返回值的使用》在Go语言中,函数可以为其返回值指定名称,这被称为命名返回值或命名返回参数,这种特性可以使代码更清晰,特别是在返回多个值时,感兴趣的可以了解一下... 目录基本语法函数命名返回特点代码示例命名特点基本语法func functionName(parameters) (nam

基于Python实现自动化邮件发送系统的完整指南

《基于Python实现自动化邮件发送系统的完整指南》在现代软件开发和自动化流程中,邮件通知是一个常见且实用的功能,无论是用于发送报告、告警信息还是用户提醒,通过Python实现自动化的邮件发送功能都能... 目录一、前言:二、项目概述三、配置文件 `.env` 解析四、代码结构解析1. 导入模块2. 加载环