本文实例为大家分享了C语言实现简单井字棋游戏的具体代码,供大家参考,具体内容如下
1.什么是井字棋
井字棋相信大部分人都玩过
规则:双方轮流放子,当某一方的三个子连成一线(行,列,对角)时,该方获胜。
2.游戏前的准备
1. 菜单
游戏正式开始前我们可以为用户提供一个选择菜单,笔者做了一个最简单的游戏开始菜单:
代码:
1
2
3
4
5
6
7
8
|
/*菜单*/
int menu()
{
printf ( "###########################\n" );
printf ( "## 1.Play 2.Exit ##\n" );
printf ( "###########################\n" );
return 0;
}
|
2. 打印棋盘
要玩游戏我们首先要有一个3*3的棋盘,棋子信息则用一个二维数组来表示,并进行初始化:
1
|
char chess[ROW][COL] = { '\0' }; //ROW=3,COL=3
|
显示棋盘我们可以写一个函数:
1
2
3
4
5
6
7
8
9
10
11
|
/*显示棋盘*/
int ShowBroad( char chess[][COL])
{
system ( "cls" ); //刷新界面
printf ( " %c | %c |%c Player: X\n" ,chess[0][0],chess[0][1],chess[0][2]);
printf ( " ---------- Computer: O\n" );
printf ( " %c | %c |%c \n" , chess[1][0], chess[1][1], chess[1][2]);
printf ( " ----------\n" );
printf ( " %c | %c |%c \n" , chess[2][0], chess[2][1], chess[2][2]);
}
|
将棋盘打印出来的同时在旁边显示出玩家和电脑所用的棋子。棋盘效果:
由于电脑是随机落子的,这样我们就会用到随机数,于是可以在后面加上随机数的种子,为之后的随机数做准备。
至此,准备工作就完成了,这部分的代码如下:
1
2
3
4
5
6
7
8
|
int a ,count =0;
char chess[ROW][COL] = { '\0' };
menu(); //显示菜单
printf ( "Please Enter Your Chose:>\n " );
scanf ( "%d" , &a);
if (a != 1){ return 0; }
ShowBroad(chess);
srand ((unsigned) time (NULL));
|
其中count是用来统计已占用的格子。
3.游戏开始
做完准备工作后我们开始正式的游戏逻辑编写。游戏逻辑可以这样考虑:
先由用户输入一个坐标,进行胜负和平局判断,若未产生任何结果则由电脑落子,之后同样进行胜负判断,如此循环直到产生胜负或平局。
基于此,我们将所有游戏过程写在一个死循环中,直到产生游戏结果则跳出。
1. 玩家落子
代码:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
|
if ((user_x >= 1 && user_x <= 3) && (user_y >= 1 && user_y <= 3)&&\
chess[user_x-1][user_y-1]== '\0' ){ //输入是否合法
chess[user_x - 1][user_y - 1] = 'X' ;
count++;
if (Judge(chess) == 'X' ){ //判断玩家赢
ShowBroad(chess);
printf ( "You Win! :)\n" );
break ;
}
else if (count == 9){ //判断平局
ShowBroad(chess);
printf ( "Draw!\n" );
break ;
}
|
解释:当用户输入坐标在棋盘内并且该位置尚未被落子时,(user_x >= 1 && user_x <= 3) && (user_y >= 1 && user_y <= 3)&&\ chess[user_x-1][user_y-1]=='\0')将棋盘对应坐标元素改写成“X”(chess[user_x - 1][user_y - 1] = 'X';),之后将格子占用数count+1.
2. 判断胜平
为了判断是否胜利,我们可以写一个函数,将棋盘现在的数据传入,在里面逐行逐列判断。
代码:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
|
/*判断*/
char Judge( char chess[][COL])
{
for ( int i = 0; i < COL; i++){ //判断行
if (chess[i][0] == chess[i][1] && chess[i][1] == chess[i][2] && chess[i][2] != '\0' )
{
return chess[i][0];
}
}
for ( int i = 0; i < COL; i++){ //判断列
if (chess[0][i] == chess[1][i] && chess[1][i] == chess[2][i] && chess[2][i] != '\0' )
{
return chess[0][i];
}
}
if (chess[0][0] == chess[1][1] && chess[1][1] == chess[2][2] && chess[2][2] != '\0' )
{ //判断对角线
return chess[0][0];
}
if (chess[0][2] == chess[1][1] && chess[1][1] == chess[2][0] && chess[2][0] != '\0' )
{
return chess[0][2];
}
return ' ' ;
}
|
此时是玩家落子之后,不会产生负,所以不需要判断是否输了。检查Judge()的返回值。当玩家胜利时输出胜利,游戏结束,当平局时输出平局,游戏结束
1
2
3
4
5
6
7
8
9
10
|
if (Judge(chess) == 'X' ){ //判断玩家赢
ShowBroad(chess);
printf ( "You Win! :)\n" );
break ;
}
else if (count == 9){ //判断平局
ShowBroad(chess);
printf ( "Draw!\n" );
break ;
}
|
3. 电脑落子
电脑是随机落子的,于是需要给chess()传入随机的x和y,于是这里用到rand()
1
2
3
4
5
6
7
8
9
10
11
12
13
|
void computer( char chess[][COL])
{
int x, y;
while (1){
x = rand () % (COL) + 0;
y = rand () % (COL) + 0;
if (chess[x][y] == '\0' ){
chess[x][y] = 'O' ;
break ;
}
}
ShowBroad(chess);
}
|
这里要注意当随机的坐标未被落子时才能使用,所以用死循环来查找一个合法的坐标,当找到时电脑才能落子,之后跳出循环,并刷新棋盘。
4. 判断负
与上面一样,我们调用Judge()函数来判断,当返回的是“O”时候,输出信息,游戏结束。
1
2
3
4
|
if (Judge(chess) == 'O' ){ //判断电脑赢
printf ( "You Lost!\n" );
break ;
}
|
最终游戏界面:
结束
至此,一个简单的井字棋游戏就完成了,内容简陋,可以优化的地方还有很多,各位可自行扩展。由这个简单的三子棋我们还能进一步发展成五子棋,做出更多的内容,先挖个五子棋的坑,以后来填。
main函数代码:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
|
int main()
{
int a ,count =0;
char chess[ROW][COL] = { '\0' };
menu(); //显示菜单
printf ( "Please Enter Your Chose:>\n " );
scanf ( "%d" , &a);
if (a != 1){ return 0; }
ShowBroad(chess);
srand ((unsigned) time (NULL));
while (1)
{
int user_x, user_y;
printf ( "Please Enter:<x,y>\n" );
scanf ( "%d%d" , &user_x, &user_y); //玩家落子
if ((user_x >= 1 && user_x <= 3) && (user_y >= 1 && user_y <= 3)&&\
chess[user_x-1][user_y-1]== '\0' ){ //输入是否合法
chess[user_x - 1][user_y - 1] = 'X' ;
count++;
if (Judge(chess) == 'X' ){ //判断玩家赢
ShowBroad(chess);
printf ( "You Win! :)\n" );
break ;
}
else if (count == 9){ //判断平局
ShowBroad(chess);
printf ( "Draw!\n" );
break ;
}
computer(chess); //电脑落子
count++;
if (Judge(chess) == 'O' ){ //判断电脑赢
printf ( "You Lost!\n" );
break ;
}
}
else continue ;
}
system ( "pause" );
return 0;
}
|
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持服务器之家。
原文链接:https://blog.csdn.net/qq_41913884/article/details/83623508