網(wǎng)站首頁 編程語言 正文
本文實例為大家分享了C語言實現(xiàn)五子棋小游戲的具體代碼,供大家參考,具體內(nèi)容如下
#include<stdio.h>
#include<windows.h>
#define ROW 14
#define COL 14
?
void gotoxy(int x,int y)//形參
{
?? ?HANDLE hOut;
?? ?COORD pos= {x,y};
?? ?// 光標的起始位(第1列,第3行) 0是第1列 2是第3行
?? ?hOut = GetStdHandle(STD_OUTPUT_HANDLE);
?? ?SetConsoleCursorPosition(hOut, pos);
?? ?//printf("定位光標位置搜索(%d,%d)\n",pos.X,pos.Y);
}
?
/*
函數(shù)名:paintGameUI()
函數(shù)功能:繪制棋盤
函數(shù)參數(shù):無
函數(shù)返回值:無
*/
void paintGameUI() ?//打印游戲棋盤 ?使用ROW COL在上面宏定義可以改變//棋盤大小
{
?? ?int i=0;
?? ?int j=0;
?? ?printf("┌ ");?? ? //頂部
?? ?for(i=0;i<COL;i++)
?? ?{
? ? ? ? printf("┬ ");
?? ?}
?? ?printf("┐\n");
?? ?//中間
?? ?for(j=0;j<ROW;j++)
?? ?{
?? ??? ?printf("├ ");
?? ??? ?for(i=0;i<COL;i++)
?? ??? ?{
?? ??? ??? ?printf("┼ ");?? ?
?? ??? ?}
?? ??? ?printf("┤\n");
?? ?}
?? ?//底部
?? ?printf("└ ");
?? ?for(i=0;i<COL;i++)
?? ?{
? ? ? ? printf("┴ ");
?? ?}
?? ?printf("┘\n");
}
?
void playgame()
{
?? ?int arr[ROW][COL]={0}; // 初始化 0-沒有棋子 1用戶下棋黑 2電腦下棋白
?? ?int x,y; ? ? ?//用戶輸入的行 列
?? ?int row,col; ?//落子的位置
?? ?int i,j; // ?規(guī)則 ? 判斷輸贏 遍歷二維數(shù)組
?? ?paintGameUI(); ? ? //?? ?繪制棋盤
?? ?while(1)//確保多次 確保用戶電腦有效落子多次
?? ?{
?? ??? ?while(1) ? ?// ? ? ?保證用戶能夠有效落子一次 用戶下棋
?? ??? ?{
?? ??? ??? ?gotoxy(0,16);//打印文字 0距離左邊 16距離頂部
?? ??? ??? ?printf(" ? ? ? ? ? ? ? ? ? ? ? ?"); ?//覆蓋掉用戶之前所輸,//讓用戶可以再輸
?? ??? ??? ?gotoxy(0,16); //打印文字 0距離左邊 16距離頂部
?? ??? ??? ?
?? ??? ??? ?printf("請輸入下棋的位置,例如:(2 3):");
?? ??? ??? ?scanf("%d %d",&x,&y);
?? ??? ??? ?row = x-1; ?//行 距離頂部的長度 數(shù)組是0開始的
?? ??? ??? ?col =y-1; ?//列 距離左邊的長度 下棋的位置
?? ??? ??? ?if(arr[row][col]==0) ? //下棋位置是否是棋子
?? ??? ??? ?{ ??
?? ??? ??? ??? ?gotoxy(col*2,row);?
?? ??? ??? ??? ?printf("●");//用戶下棋
?? ??? ??? ??? ?//修改二維數(shù)組的值
?? ??? ??? ??? ?arr[row][col]=1; //用戶下棋
?? ??? ??? ??? ?for(i=0;i<ROW;i++) ? ?
?? ??? ??? ??? ?{?? ?
?? ??? ??? ??? ??? ?for(j=0;j<COL;j++) ??
?? ??? ??? ??? ??? ?{
?? ??? ??? ??? ??? ??? ?//橫著五個都是1 ?列變
?? ??? ??? ??? ??? ??? ?if( arr[i][j]==arr[i][j+1]&&arr[i][j]==arr[i][j+2]&&?
?? ??? ??? ??? ??? ??? ??? ?arr[i][j]==arr[i][j+3]&&arr[i][j]==arr[i][j+4]&&j+4<=COL&&arr [i][j]==1)
?? ??? ??? ??? ??? ??? ?{
?? ??? ??? ??? ??? ??? ??? ?gotoxy(0,18);
?? ??? ??? ??? ??? ??? ??? ?printf("用戶贏了\n");
?? ??? ??? ??? ??? ??? ??? ?return ; ? ?
?? ??? ??? ??? ??? ??? ??? ?
?? ??? ??? ??? ??? ??? ?}//豎著五個都是1 行變
?? ??? ??? ??? ??? ??? ?else if(arr[i][j]==arr[i+1][j]&&arr[i][j]==arr[i+2][j]&&?
?? ??? ??? ??? ??? ??? ??? ?arr[i][j]==arr[i+3][j]&&arr[i][j]==arr[i+4][j]&&i+4<=ROW&&arr [i][j]==1)
?? ??? ??? ??? ??? ??? ?{
?? ??? ??? ??? ??? ??? ??? ?gotoxy(0,18);
?? ??? ??? ??? ??? ??? ??? ?printf("用戶贏了\n");
?? ??? ??? ??? ??? ??? ??? ?return ; ??
?? ??? ??? ??? ??? ??? ?}?? ?
?? ??? ??? ??? ??? ?}
?? ??? ??? ??? ?}
?? ??? ??? ??? ?break; ? ?//輪到對方下棋?? ?
?? ??? ??? ?}
?? ??? ??? ?else if(arr[row][col]==1||arr[row][col]==2) ?//用戶下棋1 電腦下棋2
?? ??? ??? ?{
?? ??? ??? ??? ?gotoxy(0,17);
?? ??? ??? ??? ?printf("請重新輸入坐標");
?? ??? ??? ?}?? ?
?? ??? ?}
?? ??? ?while(1) // ? ?確保電腦有效落子一次 電腦下棋
?? ??? ?{
?? ??? ??? ?//電腦下棋 ?電腦隨機落子
?? ??? ??? ?row= rand()%14+0; ?//二維數(shù)組索引0-13 ?
?? ??? ??? ?col= rand()%14+0; ?//電腦隨機落子
?? ??? ??? ?//行距離頂部row ?列距離左邊col
?? ??? ??? ?if(arr[row][col]==0) ? //下棋位置是否是棋子 空 電腦可以下棋
?? ??? ??? ?{ ??
?? ??? ??? ??? ?gotoxy(col*2,row);
?? ??? ??? ??? ?printf("○");//下棋
?? ??? ??? ??? ?//修改二維數(shù)組的值
?? ??? ??? ??? ?arr[row][col]=2; //電腦下棋
?? ??? ??? ??? ?for(i=0;i<ROW;i++) ? ? //電腦贏 最好用算法
?? ??? ??? ??? ?{
?? ??? ??? ??? ??? ?for(j=0;j<COL;j++)
?? ??? ??? ??? ??? ?{
?? ??? ??? ??? ??? ??? ?//橫著五個都是1 ?列變
?? ??? ??? ??? ??? ??? ?if( arr[i][j]==arr[i][j+1]&&arr[i][j]==arr[i][j+2]&&?
?? ??? ??? ??? ??? ??? ??? ?arr[i][j]==arr[i][j+3]&&arr[i][j]==arr[i][j+4]&&j+4<=COL&&arr [i][j]==2)
?? ??? ??? ??? ??? ??? ?{
?? ??? ??? ??? ??? ??? ??? ?gotoxy(0,18);
?? ??? ??? ??? ??? ??? ??? ?printf("電腦贏了\n");
?? ??? ??? ??? ??? ??? ??? ?return;
?? ??? ??? ??? ??? ??? ??? ?
?? ??? ??? ??? ??? ??? ?}//豎著五個都是1
?? ??? ??? ??? ??? ??? ?else if(arr[i][j]==arr[i+1][j]&&arr[i][j]==arr[i+2][j]&&?
?? ??? ??? ??? ??? ??? ??? ?arr[i][j]==arr[i+3][j]&&arr[i][j]==arr[i+4][j]&&i+4<=ROW&&arr [i][j]==2)
?? ??? ??? ??? ??? ??? ?{
?? ??? ??? ??? ??? ??? ??? ?gotoxy(0,18);
?? ??? ??? ??? ??? ??? ??? ?printf("電腦贏了\n");
?? ??? ??? ??? ??? ??? ??? ?return;?
?? ??? ??? ??? ??? ??? ?}?? ?
?? ??? ??? ??? ??? ?}
?? ??? ??? ??? ?}
?? ??? ??? ??? ?break;?? ?
?? ??? ??? ?}?? ?
?? ??? ?}?? ?
?? ?}
}
?
int main()
{
?? ?playgame();?? ?
?? ?return 0;
}
原文鏈接:https://blog.csdn.net/m0_56051805/article/details/124103203
相關推薦
- 2023-01-31 GraphQL在Django中的使用教程_python
- 2022-07-31 Python加密與解密模塊hashlib與hmac_python
- 2022-11-06 解析PyCharm集成GitLab代碼倉的問題_python
- 2023-01-26 C#實現(xiàn)批量Word轉(zhuǎn)換Html的示例代碼_C#教程
- 2022-11-27 Go?微服務開發(fā)框架DMicro設計思路詳解_Golang
- 2022-07-13 Python字符串中如何去除數(shù)字之間的逗號_python
- 2022-08-21 python深度學習tensorflow入門基礎教程示例_python
- 2023-02-09 最新解決'nvidia-smi'?不是內(nèi)部或外部命令也不是可運行的程序_python
- 最近更新
-
- window11 系統(tǒng)安裝 yarn
- 超詳細win安裝深度學習環(huán)境2025年最新版(
- Linux 中運行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎操作-- 運算符,流程控制 Flo
- 1. Int 和Integer 的區(qū)別,Jav
- spring @retryable不生效的一種
- Spring Security之認證信息的處理
- Spring Security之認證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權(quán)
- redisson分布式鎖中waittime的設
- maven:解決release錯誤:Artif
- restTemplate使用總結(jié)
- Spring Security之安全異常處理
- MybatisPlus優(yōu)雅實現(xiàn)加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務發(fā)現(xiàn)-Nac
- Spring Security之基于HttpR
- Redis 底層數(shù)據(jù)結(jié)構(gòu)-簡單動態(tài)字符串(SD
- arthas操作spring被代理目標對象命令
- Spring中的單例模式應用詳解
- 聊聊消息隊列,發(fā)送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠程分支