基于linux系统c语言五子棋

时间: 2023-07-28 18:07:14 浏览: 51
下面是一个基于 Linux 系统的 C 语言五子棋游戏示例代码,使用 ANSI 转义序列实现彩色输出: ```c #include <stdio.h> #include <stdlib.h> #define BOARD_SIZE 15 // 棋盘大小 int board[BOARD_SIZE][BOARD_SIZE] = {0}; // 棋盘,0 表示空,1 表示黑子,2 表示白子 // 初始化棋盘 void init_board() { int i, j; for (i = 0; i < BOARD_SIZE; i++) { for (j = 0; j < BOARD_SIZE; j++) { board[i][j] = 0; } } } // 绘制棋盘 void draw_board() { int i, j; printf("\033[2J"); // 清屏 printf("\033[1;1H"); // 光标移动到第一行第一列 printf(" "); // 左上角留空 for (i = 0; i < BOARD_SIZE; i++) { printf("%2d", i + 1); // 打印列号 } printf("\n"); for (i = 0; i < BOARD_SIZE; i++) { printf("%2d", i + 1); // 打印行号 for (j = 0; j < BOARD_SIZE; j++) { if (board[i][j] == 0) { printf(" ."); // 空位 } else if (board[i][j] == 1) { printf(" \033[1;30m@\033[0m"); // 黑子 } else if (board[i][j] == 2) { printf(" \033[1;37mO\033[0m"); // 白子 } } printf("\n"); } } // 判断是否胜利 int is_win(int player) { int i, j, k, l; for (i = 0; i < BOARD_SIZE; i++) { for (j = 0; j < BOARD_SIZE; j++) { if (board[i][j] == player) { // 判断水平方向 for (k = 0; k < 5 && j + k < BOARD_SIZE && board[i][j + k] == player; k++); if (k == 5) { return 1; } // 判断垂直方向 for (k = 0; k < 5 && i + k < BOARD_SIZE && board[i + k][j] == player; k++); if (k == 5) { return 1; } // 判断正斜方向 for (k = 0; k < 5 && i + k < BOARD_SIZE && j + k < BOARD_SIZE && board[i + k][j + k] == player; k++); if (k == 5) { return 1; } // 判断反斜方向 for (k = 0; k < 5 && i + k < BOARD_SIZE && j - k >= 0 && board[i + k][j - k] == player; k++); if (k == 5) { return 1; } } } } return 0; } // 判断是否平局 int is_draw() { int i, j; for (i = 0; i < BOARD_SIZE; i++) { for (j = 0; j < BOARD_SIZE; j++) { if (board[i][j] == 0) { return 0; } } } return 1; } int main() { int x, y; int player = 1; // 玩家,默认黑子先行 init_board(); // 初始化棋盘 while (1) { draw_board(); // 绘制棋盘 if (is_win(player)) { printf("\033[1;33mPlayer %d wins!\033[0m\n", player); break; } else if (is_draw()) { printf("\033[1;33mDraw game!\033[0m\n"); break; } printf("Player %d's turn: ", player); scanf("%d%d", &x, &y); if (x < 1 || x > BOARD_SIZE || y < 1 || y > BOARD_SIZE) { printf("\033[1;31mInvalid position!\033[0m\n"); continue; } if (board[x - 1][y - 1] != 0) { printf("\033[1;31mThis position is occupied!\033[0m\n"); continue; } board[x - 1][y - 1] = player; player = (player == 1) ? 2 : 1; // 切换玩家 } return 0; } ``` 该示例代码实现了基本的五子棋游戏功能,可以在终端上进行游戏,并支持彩色输出。需要注意的是,该代码仅供参考,实际应用中还需要进行一些改进和优化。

相关推荐

最新推荐

recommend-type

基于Linux操作系统C语言开发的多人聊天室程序设计与实现.docx

里面附有源代码,加上详细的设计步骤,使用了C语言开发,功能有服务器和客户端的消息接收与发送,以及退出功能
recommend-type

C语言五子棋实验报告.docx

使用C语言基于EGE图形库实现的五子棋小游戏,实验报告,C语言程序设计的结课作业,实现了人机对弈与人人对战功能。有相应的音乐
recommend-type

基于C语言实现点餐系统

主要为大家详细介绍了基于C语言实现点餐系统,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
recommend-type

C语言实现简单航班管理系统

主要为大家详细介绍了C语言实现简单航班管理系统,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
recommend-type

餐馆点菜系统C语言源代码

主要为大家详细介绍了餐馆点菜系统C语言源代码,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
recommend-type

zigbee-cluster-library-specification

最新的zigbee-cluster-library-specification说明文档。
recommend-type

管理建模和仿真的文件

管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire
recommend-type

实现实时数据湖架构:Kafka与Hive集成

![实现实时数据湖架构:Kafka与Hive集成](https://img-blog.csdnimg.cn/img_convert/10eb2e6972b3b6086286fc64c0b3ee41.jpeg) # 1. 实时数据湖架构概述** 实时数据湖是一种现代数据管理架构,它允许企业以低延迟的方式收集、存储和处理大量数据。与传统数据仓库不同,实时数据湖不依赖于预先定义的模式,而是采用灵活的架构,可以处理各种数据类型和格式。这种架构为企业提供了以下优势: - **实时洞察:**实时数据湖允许企业访问最新的数据,从而做出更明智的决策。 - **数据民主化:**实时数据湖使各种利益相关者都可
recommend-type

用matlab绘制高斯色噪声情况下的频率估计CRLB,其中w(n)是零均值高斯色噪声,w(n)=0.8*w(n-1)+e(n),e(n)服从零均值方差为se的高斯分布

以下是用matlab绘制高斯色噪声情况下频率估计CRLB的代码: ```matlab % 参数设置 N = 100; % 信号长度 se = 0.5; % 噪声方差 w = zeros(N,1); % 高斯色噪声 w(1) = randn(1)*sqrt(se); for n = 2:N w(n) = 0.8*w(n-1) + randn(1)*sqrt(se); end % 计算频率估计CRLB fs = 1; % 采样频率 df = 0.01; % 频率分辨率 f = 0:df:fs/2; % 频率范围 M = length(f); CRLB = zeros(M,1); for
recommend-type

JSBSim Reference Manual

JSBSim参考手册,其中包含JSBSim简介,JSBSim配置文件xml的编写语法,编程手册以及一些应用实例等。其中有部分内容还没有写完,估计有生之年很难看到完整版了,但是内容还是很有参考价值的。