棋盘游戏(3*3)
2015-07-28 18:30
393 查看
#include <stdio.h>
void init_board(char arr[][3])
{
int i=0;
int j=0;
for(i=0;i<3;i++)
{
for(j=0;j<3;j++)
{
arr[i][j]=' ';
}
}
}
void show_board(char arr[][3])
{
int i=0;
for(i=0;i<3;i++)
{
printf(" %c | %c | %c ",arr[i][0],arr[i][1],arr[i][2]);
if(i!=2)
printf("\n---|---|---\n");
}
printf("\n");
}
void player_move(char arr[][3])
{
int x,y;
printf("请输入坐标括");
scanf("%d%d",&x,&y);
if(arr[x-1][y-1]!=' ')
{
printf("该位置已经被占有:");
player_move(arr);
}
else
{
arr[x-1][y-1]='x';
}
}
void computer_move(char arr[][3])
{
int i=0;
int j=0;
for(i=0;i<3;i++)
{
for(j=0;j<3;j++)
{
if(arr[i][j]==' ')
{
arr[i][j]='0';
return 0;
}
}
if(arr[i][j]=='0')
break;
}
}
char check(char arr[][3])
{
int i=0;
char key;
for(i=0;i<3;i++)
{
if((arr[i][0]!=' ')&&(arr[i][0]==arr[i][1])&&(arr[i][1]==arr[i][2]))
key=arr[i][0];
if((arr[0][i]!=' ')&&(arr[0][i]==arr[1][i])&&(arr[1][i]==arr[2][i]))
key=arr[0][i];
if((arr[i][i]!=' ')&&(arr[0][0]==arr[1][1])&&(arr[1][1]==arr[2][2]))
key=arr[i][i];
if((arr[0][2]!=' ')&&(arr[0][2]==arr[1][1])&&(arr[1][1]==arr[2][0]))
key=arr[0][2];
}
if(key=='x')
{
printf("玩家赢!\n");
return 1;
}
else if(key=='0')
{
printf("电脑赢!\n");
return 0;
}
else
return -1;
}
int main()
{
int done;
char arr[3][3];
init_board(arr);
show_board(arr);
do
{
player_move(arr);
done=check(arr);
if(done!=-1)
break;
computer_move(arr);
done=check(arr);
show_board(arr);
}while(done==-1);
return 0;
}
该游戏比较简单,并没有实现电脑的智能性。
void init_board(char arr[][3])
{
int i=0;
int j=0;
for(i=0;i<3;i++)
{
for(j=0;j<3;j++)
{
arr[i][j]=' ';
}
}
}
void show_board(char arr[][3])
{
int i=0;
for(i=0;i<3;i++)
{
printf(" %c | %c | %c ",arr[i][0],arr[i][1],arr[i][2]);
if(i!=2)
printf("\n---|---|---\n");
}
printf("\n");
}
void player_move(char arr[][3])
{
int x,y;
printf("请输入坐标括");
scanf("%d%d",&x,&y);
if(arr[x-1][y-1]!=' ')
{
printf("该位置已经被占有:");
player_move(arr);
}
else
{
arr[x-1][y-1]='x';
}
}
void computer_move(char arr[][3])
{
int i=0;
int j=0;
for(i=0;i<3;i++)
{
for(j=0;j<3;j++)
{
if(arr[i][j]==' ')
{
arr[i][j]='0';
return 0;
}
}
if(arr[i][j]=='0')
break;
}
}
char check(char arr[][3])
{
int i=0;
char key;
for(i=0;i<3;i++)
{
if((arr[i][0]!=' ')&&(arr[i][0]==arr[i][1])&&(arr[i][1]==arr[i][2]))
key=arr[i][0];
if((arr[0][i]!=' ')&&(arr[0][i]==arr[1][i])&&(arr[1][i]==arr[2][i]))
key=arr[0][i];
if((arr[i][i]!=' ')&&(arr[0][0]==arr[1][1])&&(arr[1][1]==arr[2][2]))
key=arr[i][i];
if((arr[0][2]!=' ')&&(arr[0][2]==arr[1][1])&&(arr[1][1]==arr[2][0]))
key=arr[0][2];
}
if(key=='x')
{
printf("玩家赢!\n");
return 1;
}
else if(key=='0')
{
printf("电脑赢!\n");
return 0;
}
else
return -1;
}
int main()
{
int done;
char arr[3][3];
init_board(arr);
show_board(arr);
do
{
player_move(arr);
done=check(arr);
if(done!=-1)
break;
computer_move(arr);
done=check(arr);
show_board(arr);
}while(done==-1);
return 0;
}
该游戏比较简单,并没有实现电脑的智能性。
相关文章推荐
- 注册时重复密码验证和登录为空处理
- Java 中的方法内部类
- RecyclerView
- Android 异步消息处理机制 让你深入理解 Looper、Handler、Message三者关系
- 多校第三场 1002 hdu 5317 RGCDQ (筛素数+前缀和)
- 20150728
- LINK : fatal error LNK1123: 转换到 COFF 期间失败: 文件无效或损坏
- Save__TangMonk之状态压缩
- How to set up and test a simple OLEDB Linked Server in Microsoft® SQL Server to allow retrieval of d
- KVO崩溃之解决办法
- 利用selector设置ImageButton不同状态下的背景图片
- IOS- 内存中堆和栈的区别
- Android ScrollView下拉图片变大
- 数字图像处理01(插值)
- 2015 Multi-University Training Contest 3(hdu 5316、5317、5319、5323、5325、5326)线段树+数学+yy+矩阵快速幂
- Linux中用户和用户组的管理以及如何批量创建用户
- uboot 学习笔记 stage 2
- 在ListView的adapter里面写了item的点击事件和整行的点击事件冲突
- 黑马程序员——自学总结(七)图形用户界面GUI
- ios学习笔记-(oc基础-面向对象小系统)