C语言实现三子棋游戏

 更新时间:2020年04月08日 10:10:05   作者:午饭要阳光  
这篇文章主要为大家详细介绍了C语言实现三子棋游戏的方法,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

本文实例为大家分享了C语言实现三子棋游戏的具体代码,供大家参考,具体内容如下

#include<stdio.h> 
#include<stdlib.h> 
#include<time.h> 
 
void chess_board(char arr[3][3]) //打印棋盘 
{ 
 int i = 0; 
 int j = 0; 
 for (i = 0; i < 3; i++) 
 { 
 printf( " %c | %c | %c \n", arr [i][0], arr[i][1], arr[i][2]); 
 if (i<2) 
 printf( "---|---|---\n"); 
 } 
} 
 
int success_or_failure(char arr[3][3]) //判断胜负 
{ 
 int i = 0; 
 int j = 0; 
 for (i = 0; i < 3; i++) 
 { 
 if ((arr [i][0] == arr[i][1]) && ( arr[i][j] == arr [i][2])) 
 { 
 if (arr [i][0] == '#') 
  return 1; //用户赢了 
 else if (arr[i][0] == '0') 
  return -1; //电脑赢了 
 } 
 } 
 for (j = 0; j < 3; j++) 
 { 
 if ((arr [0][j] == arr[1][j]) && ( arr[1][j] == arr [2][j])) 
 { 
 if (arr [0][j] == '#') 
 return 1;  //用户赢了 
 else if (arr[0][j] == '0') 
 return -1; //电脑赢了 
 } 
 } 
 if ((arr [0][0] == arr[1][1]) && ( arr[0][0] == arr [2][2])) 
 { 
 if (arr [1][1] == '#') 
  return 1; //用户赢了 
 else if (arr[1][1] == '0') 
  return -1; //电脑赢了 
 } 
 if ((arr [0][2] == arr[1][1]) && ( arr[0][2] == arr [2][0])) 
 { 
 if (arr [1][1] == '#') 
  return 1; //用户赢了 
 else if (arr[1][1] == '0') 
  return -1; //电脑赢了 
 } 
 for (i = 0; i < 3; i++) 
 { 
 for (j = 0; j < 3; j++) 
  { 
  if (arr [i][j] == ' ') 
  return 0; //都没赢 
  } 
 } 
 return -2;  //平局 
} 
 
int user_game(char arr[3][3])  //用户输入 
{ 
 int x = 0; 
 int y = 0; 
 while (1) 
 { 
 printf( "please user input:(x, y) "); 
 scanf( "%d%d", &x, &y); 
 printf( "\n"); 
 if ((x<1 && x>3) || (y<1 && y>3)) //判断用户输入的是否合法 
 { 
 printf( "地址无效,请重新输入\n" );  
 break; 
 } 
 if (arr [x - 1][y - 1] == ' ') //判断这个位置有没有被占 
 {    
 arr[x - 1][y - 1] = '#' ; 
 break; 
 } 
 printf( "地址无效,请重新输入\n" ); 
 } 
 chess_board( arr); 
 int ret=success_or_failure(arr ); 
 return ret; 
} 
 
int computer_game(char arr[3][3])  //电脑输入 
{ 
 printf( "computer input:\n\n"); 
 int x = 0; 
 int y = 0; 
 while (1) 
 {  //产生一个没有被棋子占用的位置 
 srand(( unsigned)time(NULL )); 
 x = rand() % 3; 
 srand(( unsigned)time(NULL )); 
 y = rand() % 3; 
 if (arr [x][y] == ' ')   
 break; 
 } 
 arr[x][y]= '0' ; 
 chess_board(arr); 
 int ret=success_or_failure(arr); 
 return ret; 
} 
 
 
void init(char arr[][3])  //初始化棋盘 
{ 
 
 for (int i = 0; i < 3; i++)  
 { 
 for (int j = 0; j<3; j++) 
 { 
 arr[i][j] = ' '; 
 } 
 } 
} 
 
int main() 
{ 
 printf( "**********************\n"); //打印菜单 
 printf( "******* *******\n"); 
 printf( "*******1.go 0.exit**\n"); 
 printf( "******* *******\n"); 
 printf( "**********************\n"); 
 printf( "**********************\n\n\n"); 
 char arr[3][3]; 
 while (1) 
 { 
 init(arr);  //初始化棋盘 
 int count = 0; 
 printf( "\nplease choice:1 or 0 : " ); 
 scanf( "%d", &count); //选择功能 
 if (count == 0) 
 { 
 exit( EXIT_FAILURE); 
 } 
 else if (count == 1) 
 { 
 printf( "\n****游戏开始****\n\n" ); 
 while (1) 
 { int n1 = user_game(arr); 
 { 
 if (n1 == 1) 
 { 
  printf( "****恭喜玩家赢了****\n" ); 
  break; 
 } 
 }  
 int n2 = computer_game(arr);   
 { 
  if (n2 == -1) 
  { 
  printf( "****电脑赢了****\n" ); 
  break; 
  } 
 } 
 if ((n1 == -2) || (n2 == -2))  
 { 
 printf( "*****平局******\n" ); 
 break; 
 } 
 } 
  printf( "\n再来一局\n\n" ); 
 } 
 return 0; 
} 

更多有趣的经典小游戏实现专题,分享给大家:

C++经典小游戏汇总

python经典小游戏汇总

python俄罗斯方块游戏集合

JavaScript经典游戏 玩不停

java经典小游戏汇总

javascript经典小游戏汇总

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

相关文章

  • C++ Leetcode实现从英文中重建数字

    C++ Leetcode实现从英文中重建数字

    本文主要介绍了当给你一个字符串s,其中包含字母顺序打乱的用英文单词表示的若干数字(0-9)时,如何通过Leetcode按升序返回原始的数字。感兴趣的童鞋可以来看看
    2021-11-11
  • C++简明分析讲解引用与函数提高及重载

    C++简明分析讲解引用与函数提高及重载

    今天继续开始对C++核心编程知识的分享与系统讲解,第一,这里会提到“引用”方法传参以及剖析引用的本质;第二,我们对函数来一个提高,相当于进阶函数了,包括函数的默认值,简单的提一下函数的占位参数,函数重载以及注意事项,接下来上正文
    2022-05-05
  • 浅谈socket TCP编程中connect的一些坑

    浅谈socket TCP编程中connect的一些坑

    下面小编就为大家带来一篇浅谈socket TCP编程中connect的一些坑。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2016-12-12
  • 详解C++中存储类的使用

    详解C++中存储类的使用

    存储类定义 C++ 程序中变量/函数的范围(可见性)和生命周期。这些说明符放置在它们所修饰的类型之前。auto、register、static、extern和mutable是C++程序中常用的存储类,本文主要介绍了它们的使用方法,需要的可以参考一下
    2022-12-12
  • 深入解析C++的循环链表与双向链表设计的API实现

    深入解析C++的循环链表与双向链表设计的API实现

    这篇文章主要介绍了C++的循环链表与双向链表设计的API实现,文中的示例对于链表结点的操作起到了很好的说明作用,需要的朋友可以参考下
    2016-03-03
  • Qt中QList与QLinkedList类的常用方法总结

    Qt中QList与QLinkedList类的常用方法总结

    这篇文章主要为大家详细介绍了Qt中QList与QLinkedList类的常用方法,文中的示例代码讲解详细,对我们学习Qt有一定的帮助,需要的可以参考一下
    2022-12-12
  • C++实现四则运算器(无括号)

    C++实现四则运算器(无括号)

    这篇文章主要为大家详细介绍了C++实现四则运算器,无括号的计算器,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2020-11-11
  • C++中获取字符串长度的函数sizeof()、strlen()、length()、size()详解和区别(推荐)

    C++中获取字符串长度的函数sizeof()、strlen()、length()、size()详解和区别(推荐)

    在C++中计算长度的函数有四种,它们分别是sizeof() ,size(),strlen(),str.length(),这篇文章主要介绍了C++中获取字符串长度的函数sizeof()、strlen()、length()、size()详解和区别,需要的朋友可以参考下
    2023-02-02
  • Opencv基于文字检测去图片水印的实现示例

    Opencv基于文字检测去图片水印的实现示例

    去水印是个麻烦事,本文就来介绍一种方法Opencv基于文字检测去图片水印的实现示例,具有一定的参考价值,感兴趣的可以了解一下
    2023-09-09
  • C#开源类库SimpleTCP使用方法

    C#开源类库SimpleTCP使用方法

    SimpleTCP内部有一个特殊字符分割字符串的协议可以直接使用,也可以在DataReceived事件处理程序中实现自己的协议,这篇文章主要介绍了C#开源类库SimpleTCP的使用方法,需要的朋友可以参考下
    2021-09-09

最新评论