亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

C語言實現(xiàn)三子棋游戲

 更新時間:2020年04月08日 10:10:05   作者:午飯要陽光  
這篇文章主要為大家詳細介紹了C語言實現(xiàn)三子棋游戲的方法,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下

本文實例為大家分享了C語言實現(xiàn)三子棋游戲的具體代碼,供大家參考,具體內容如下

#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) 
 {  //產(chǎn)生一個沒有被棋子占用的位置 
 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; 
} 

更多有趣的經(jīng)典小游戲實現(xiàn)專題,分享給大家:

C++經(jīng)典小游戲匯總

python經(jīng)典小游戲匯總

python俄羅斯方塊游戲集合

JavaScript經(jīng)典游戲 玩不停

java經(jīng)典小游戲匯總

javascript經(jīng)典小游戲匯總

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

相關文章

  • C語言的字符串函數(shù),內存函數(shù)筆記詳解

    C語言的字符串函數(shù),內存函數(shù)筆記詳解

    這篇文章主要給大家介紹了關于C語言字符串/內存的相關函數(shù),文中通過示例代碼總結的非常詳細,對大家學習或者使用C語言具有一定的參考學習價值,需要的朋友們下面來一起學習學習吧
    2021-09-09
  • C++使用LibCurl實現(xiàn)Web隱藏目錄掃描功能

    C++使用LibCurl實現(xiàn)Web隱藏目錄掃描功能

    LibCurl是一個開源的免費的多協(xié)議數(shù)據(jù)傳輸開源庫,該框架具備跨平臺性,開源免費,并提供了包括HTTP、FTP、SMTP、POP3等協(xié)議的功能,本文將給大家介紹C++使用LibCurl實現(xiàn)Web隱藏目錄掃描功能
    2023-11-11
  • C++超詳細講解友元的使用

    C++超詳細講解友元的使用

    采用類的機制后實現(xiàn)了數(shù)據(jù)的隱藏與封裝,類的數(shù)據(jù)成員一般定義為私有成員,成員函數(shù)一般定義為公有的,依此提供類與外界間的通信接口。但是,有時需要定義一些函數(shù),這些函數(shù)不是類的一部分,但又需要頻繁地訪問類的數(shù)據(jù)成員,這時可以將這些函數(shù)定義為該類的友元函數(shù)
    2022-04-04
  • C語言的動態(tài)內存分配及動態(tài)內存分配函數(shù)詳解

    C語言的動態(tài)內存分配及動態(tài)內存分配函數(shù)詳解

    這篇文章主要為大家詳細介紹了C語言的動態(tài)內存分配及動態(tài)內存分配函數(shù),文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助
    2022-03-03
  • C語言高效編程的幾招小技巧

    C語言高效編程的幾招小技巧

    這篇文章主要介紹了C語言高效編程的幾招小技巧,本文講解了以空間換時間、用數(shù)學方法解決問題以及使用位操作等編輯技巧,并給出若干方法和代碼實例,需要的朋友可以參考下
    2015-05-05
  • Qt使用流處理XML文件的示例代碼

    Qt使用流處理XML文件的示例代碼

    XML(eXtensible?Markup?Language)是一種通用的文本格式,被廣泛運用于數(shù)據(jù)交換和數(shù)據(jù)存儲。本文主要來和大家聊聊如何使用?Qt?處理?XML?格式的文檔,需要的可以參考一下
    2023-02-02
  • VSCode 使用 Code Runner 插件無法編譯運行文件名帶空格的文件問題

    VSCode 使用 Code Runner 插件無法編譯運行文件名帶空格的文件問題

    這篇文章主要介紹了VSCode 使用 Code Runner 插件無法編譯運行文件名帶空格的文件問題,本文通過圖文實例相結合給大家介紹的非常詳細,需要的朋友可以參考下
    2021-07-07
  • 超詳細分析C語言動態(tài)內存管理問題

    超詳細分析C語言動態(tài)內存管理問題

    動態(tài)內存是相對靜態(tài)內存而言的。所謂動態(tài)和靜態(tài)就是指內存的分配方式。動態(tài)內存是指在堆上分配的內存,而靜態(tài)內存是指在棧上分配的內存,本文帶你深入探究C語言中動態(tài)內存的管理
    2022-04-04
  • 淺談C語言數(shù)組元素下標為何從0開始

    淺談C語言數(shù)組元素下標為何從0開始

    很多同學可能在學習數(shù)組時會有這個疑問,下標為什么不從1開始呢?本文主要介紹了淺談C語言數(shù)組元素下標為何從0開始,感興趣的可以了解一下
    2022-01-01
  • C++代碼實現(xiàn)網(wǎng)絡Ping功能

    C++代碼實現(xiàn)網(wǎng)絡Ping功能

    這篇文章主要介紹了C++代碼實現(xiàn)網(wǎng)絡Ping功能,Ping命令被送到本地計算機的IP軟件,該命令永不退出該計算機,本文給大家介紹的非常詳細,需要的朋友參考下吧
    2021-08-08

最新評論