C语言简单游戏编程入门之四子棋

article/2025/7/11 4:11:11

运行截图

在这里插入图片描述

源代码

#include<stdio.h>
#include<stdlib.h>
/*四子棋1.在一个6行7列的棋盘中2.玩家1和玩家2依次交替下子3.每次下子落于棋盘可能达到的最下方4.先四子相连为胜5.棋盘已满且无四子相连为平局 
*//*定义常量*/
//行数 
#define ROW 7
//列数 
#define COL 8
//玩家1的棋子
#define O 1
//玩家2的棋子
#define X 2
//空白
#define WHITE 0 
//胜利需要的连字数
#define COUNT 4 /*定义全局变量*/ 
int map[ROW][COL]={0};//打印地图  
void PrintMap(int map[][COL],int row,int col);
//下子
int PlayChess(int map[][COL],int col,int piece); 
//是否已经赢了
int IsWin(int map[][COL],int row,int col,int piece); int main()
{ int piece=O;int row;int col;int Winner=0;int count_piece=0;while(1){/*清屏*/system("cls");PrintMap(map,ROW-1,COL-1);if(Winner!=0||count_piece==(ROW-1)*(COL-1)){break;}printf("现在%d号玩家下子\n",piece);printf("落子位置(1~%d):",COL-1);scanf("%d",&col);if(col<1||col>=COL){printf("下子位置无效!\n");continue;}row=PlayChess(map,col,piece);if(row==0){printf("该列已经满了!\n");}else{count_piece++;Winner=IsWin(map,row,col,piece);if(Winner!=0){}else{if(piece==O){piece=X;}else if(piece==X){piece=O;}}}}if(Winner!=0){printf("%d号玩家获胜!\n",Winner);}else{printf("平局!\n");}return 0;
}//打印地图  
void PrintMap(int map[][COL],int row,int col)
{/*int i=1;while(i<=row){int j=1;while(j<=col){if(map[i][j]==O){printf("O");}else if(map[i][j]==X){printf("X");}else if(map[i][j]==WHITE){printf(" ");}j++;	}	printf("\n");i++;} */int number=1;while(number<=2*COL-2){if(number%2==0){printf("%d",number/2);}else{printf(" ");}number++;}printf("\n");int i=1;while(i<=2*ROW-1){int j=1;while(j<=2*COL-1){if(i%2==1){printf("-");}else if(j%2==1){printf(" ");}else{int h=i/2;int z=j/2;if(map[h][z]==O){printf("O");}else if(map[h][z]==X){printf("X");}else{printf(" ");}}j++;}printf("\n");i++;} 
} //下子
int PlayChess(int map[][COL],int col,int piece)
{int i=ROW-1;while(i>=1){if(map[i][col]==WHITE){map[i][col]=piece;return i;}i--;}return 0;
}//是否已经赢了
int IsWin(int map[][COL],int row,int col,int piece)
{int countH=1,countS=1,countP=1,countN=1;int i;/*计算countH*//*左边*/i=col-1;while(i>=1){if(map[row][i]==piece){countH++;}else{break;}i--;}/*右边*/i=col+1;while(i<=COL-1){if(map[row][i]==piece){countH++;}else{break;}i++;}/*计算countS*//*上边*/i=row-1;while(i>=1){if(map[i][col]==piece){countS++;	}	else{break;}i--;} /*下边*/i=row+1;while(i<=ROW-1){if(map[i][col]==piece){countS++;	}	else{break;}i++;}int j;/*计算countN*//*左上*/i=row-1;j=col-1;while(i>=1&&j>=1){if(map[i][j]==piece){countN++;}else{break;}i--;j--;}/*右下*/i=row+1;j=col+1;while(i<=ROW-1&&j<=COL-1){if(map[i][j]==piece){countN++;}else{break;}i++;j++;}/*计算countP*//*右上*/i=row-1;j=col+1;while(i>=1&&j<=COL-1){if(map[i][j]==piece){countP++;}else{break;}i--;j++;}/*左下*/i=row+1;j=col-1;while(i<=ROW-1&&j>=1){if(map[i][j]==piece){countP++;}else{break;}i++;j--;}if(countH>=COUNT||countS>=COUNT||countP>=COUNT||countN>=COUNT){return piece;}else {return 0;}
}

实现思路

整形二维数组存储棋盘
其余的比较简单,在源码中描述的比较仔细,在此不多赘述。


http://chatgpt.dhexx.cn/article/HxALCSHY.shtml

相关文章

基于Python实现四子棋游戏

1. 实验介绍 1.1 实验内容 实验利用 Python 模拟 AI 和玩家进行四子棋游戏&#xff0c;利用游戏实验 Pygame 库&#xff0c;为游戏提供界面和操作支持。AI 算法借用蒙特卡洛搜索树思想。通过设置 AI 的难度系数&#xff0c;即 AI 所能考虑到的未来棋子的可能走向&#xff0c;…

运用Python——劳拉下棋_四连环游戏_重力四子棋游戏(代码与游戏判定)

导航 运用Python——爬虫_网易云音乐热评 运用Python——游戏_四子棋_劳拉下棋 文章目录 导航1.游戏规则2.玩法分析3.部分详解第一部分&#xff1a;初始化第二部分&#xff1a;棋盘显示第三部分&#xff1a;玩家输入第四部分&#xff1a;运行第五部分&#xff1a;胜利判断 4.完…

ISME | 热液微生物群落揭示了喷口区的生物地理学和嗜热性的进化历史

Auka热液喷口区的微生物群落揭示了喷口区的生物地理学和嗜热性的进化历史 Microbial community of recently discovered Auka vent field sheds light on vent biogeography and evolutionary history of thermophily Article The ISME Journal, [IF 10.3] DOI&#xff1a;10.…

S32K1xx 固件更新

1 介绍 随着当前技术的进步&#xff0c;车辆变得更加电子化而不是机械化。车辆中的电子创新不断增加。因此&#xff0c;车辆中的软件也在增加&#xff0c;因此存在潜在错误的风险。 每次发现软件错误时&#xff0c;都需要进行召回过程来更新软件。这些召回代表了汽车制造商的…

萤火虫算法综述

1.萤火虫算法概述 萤火虫闪烁的光芒在热带和温带地区的夏季天空中是一道令人惊叹的风景。大约有两千种萤火虫&#xff0c;大多数萤火虫会发出短暂而有节奏的闪光。闪光的模式对于特定物种来说往往是独一无二的。闪光是由生物发光过程产生的&#xff0c;这种信号系统的真正功能仍…

《闪》(霹雳战狗 bolt)电影感悟

when you stuck your head, relax, turn and pull. 有时候做人做事要转换一下方式&#xff0c;否则还是会卡住头。Because all around the planet, there are animals who feel like they cannot, like a little hamster, who once spends his day in the vehicle park dreamin…

大学英语四新视野 课后习题+答案翻译 Unit1~Unit8

Unit 1 Text A: Words in use 2022年6月16日 20:57 1 As the gender barriers crumbled, the number of women working as lawyers, doctors, or bankers began to increase significantly from the mid-20th century. 随着性别障碍的消除&#xff0c;从20世纪中期开始&am…

拉勾网爬虫

源代码&#xff1a;https://github.com/carlblocking/xxw-for-public/tree/master/LaGouSpider 前几天写了一个知乎网的爬虫并爬取了一些数据&#xff0c;然而新鲜感消失的很快。于是&#xff0c;大概2天前开始试着爬取拉勾网上的数据。 在解析数据的过程中&#xff0c;知乎爬…

爬虫实战(三) 用Python爬取拉勾网

0、前言 最近博主面临着选方向的困难&#xff08;唉&#xff0c;选择困难症患者 &#xff1e;﹏&#xff1c;&#xff09;&#xff0c;所以希望了解一下目前不同岗位的就业前景 这时&#xff0c;就不妨写个小爬虫&#xff0c;爬取一下 拉勾网 的职位数据&#xff0c;并用图形…

python爬取拉勾网公司信息(您操作太频繁,请稍后访问)

最近爬取拉勾网上的公司信息碰到了很多问题&#xff0c;但是都一一解决了。作为一个招聘网站&#xff0c;他的反爬措施做的还是很好的。 为了调查招聘网站上有多少公司&#xff0c;以及公司信息&#xff0c;并把公司信息存入MongoDB数据库中。 先上运行成功代码&#xff1a; …

2022年爬取拉勾网详情页面地址信息

众所周知&#xff0c;拉勾网的反爬机制一直做的很好&#xff0c;前些年还可以通过找到网页源代码找到岗位详情页面的地址&#xff0c;而现在拉勾网的详情页面地址直接没了&#xff0c;这就很奇怪&#xff0c;那么鼠标点击他又是如何跳转到别的页面 点开源代码中&#xff0c;每一…

django+拉勾网招聘数据可视化

django拉勾网招聘数据可视化&#xff0c;此系统有详细的录屏&#xff0c;下面只是部门截图&#xff0c;需要看完整录屏联系博主 系统开发语言python&#xff0c;框架为django&#xff0c;数据库mysql&#xff0c;分为爬虫和可视化分析

Python爬虫实战:爬取拉勾网并对其进行数据分析

###整体的 思路 是采用 selenium 模拟浏览器的行为&#xff0c;具体的步骤如下&#xff1a; 初始化爬取数据&#xff0c;这里分为两个部分&#xff1a;一是爬取网页数据&#xff0c;二是进行翻页操作保存数据&#xff0c;将数据保存到文件中数据可视化 ###整体的 代码结构 如…

什么你还不知道招聘信息,小唐来教你——最新2021爬取拉勾网招聘信息(二)

文章目录 前言一、准备我们的库二、数据清洗三、核密度图及词云制作四、完整代码五、扩展 上一篇&#xff1a;什么你还不知道招聘信息&#xff0c;小唐来教你——最新2021爬取拉勾网招聘信息&#xff08;一&#xff09; 下一篇&#xff1a;没有拉&#xff01; 前言 既然我们上…

No.4 拉勾网职位搜索信息爬取

一、简介 网址&#xff1a;https://www.lagou.com/jobs/list_/p-city_0?&clfalse&fromSearchtrue&labelWords&suginput 效果&#xff1a;信息 使用框架&#xff1a;requests 难度系数&#xff1a;✩✩✩ 二、教程 今天我们要为我们的工作写爬虫&#xf…

什么你还不知道招聘信息,小唐来教你——最新2021爬取拉勾网招聘信息(一)

文章目录 前言一、准备我们的库二、分析分析三、 代码四、数据展示小唐的心路历程 上一篇&#xff1a;没有啦&#xff01; 下一篇&#xff1a;什么你还不知道招聘信息&#xff0c;小唐来教你——最新2021爬取拉勾网招聘信息&#xff08;二&#xff09; 前言 有是小唐的数据分析…

拉勾网的反爬介绍和解决方法(更新时间:2019/2/20)

拉勾网的反爬介绍和解决方法&#xff08;更新时间&#xff1a;2019/2/20&#xff09; 目录直达&#xff1a; 文章目录 拉勾网的反爬介绍和解决方法&#xff08;更新时间&#xff1a;2019/2/20&#xff09;1. 前言2. 简述3. 反爬介绍3.1、对于职位的详情页和公司的详情页的反爬…

应对反爬如何爬取拉勾网信息(非常详细)

目录 前期准备请求头Cookies问题手动提取Cookies和自动Cookies相结合自动提取Cookies实现 手动提取Cookies实现 页面分析代码实现 前期准备 我们知道百度其实就是一个爬虫&#xff0c;但是对方的服务器是没有对百度进行反爬的&#xff0c;所以为了防止对方服务器的反爬&#x…

【Python】模拟登陆并抓取拉勾网信息(selenium+phantomjs)

环境 python3.5pip install seleniumphantomjs-2.1.1pip install pyquery 代码 # -*- coding:utf-8 -*-# 防止print中文出错 import time import sys import io sys.stdout io.TextIOWrapper(sys.stdout.buffer, encodinggb18030)from pyquery import PyQuery as pq from se…

Python爬虫实战,requests模块,Python实现拉勾网求职信息数据分析与可视化

前言 利用requests爬取拉勾网求职信息数据分析与可视化&#xff0c;废话不多说。 让我们愉快地开始吧~ 开发工具 **Python版本&#xff1a;**3.6.4 相关模块&#xff1a; requests模块&#xff1b; re模块&#xff1b; os模块 jieba模块&#xff1b; pandas模块 num…