用VC++6.0實現(xiàn)石頭剪刀布游戲的程序
更新時間:2015年03月06日 09:14:15 作者:geek_monkey
最先看到這個游戲代碼是python版的,后來看到有小伙伴用VC++重寫了一遍,運行之后發(fā)現(xiàn)有些小bug,便嘗試這修復了一下,并增加了些小功能,這里分享給大家。
源程序是從網(wǎng)上看到的,
geek_monkey于2015年3月3日修改了bug(輸入字符非石頭剪刀布都算是玩家贏)
編譯環(huán)境為VC++6.0
增加“上帝模式”和數(shù)據(jù)統(tǒng)計,純屬娛樂。
我是C語言初學者,輕噴
復制代碼 代碼如下:
#include <stdio.h>
#include <stdlib.h>
#include <time.h>
#include <string.h>
int exist_in(char *arr1[][2], char *arr2[], int length);//勝負判斷函數(shù)
void nextround (void);//本輪結(jié)束后的處理輪函數(shù)
enum {QUIT,OK} status;//標志位,QUIT=0,OK=1
int vcnt = 0,dcnt = 0,tcnt = 0;//數(shù)據(jù)統(tǒng)計
int main(void)
{
int i = 0, length;
time_t t;
status = OK;
char *person = (char *) malloc(100);//動態(tài)內(nèi)存分配
char *computer = (char *) malloc(100);
char *computer_person[2];
char *guess_arr[] = {"石頭", "剪刀", "布"};
char *win[3][2] = {{"布", "石頭"}, {"石頭", "剪刀"}, {"剪刀", "布"}};
length = (int)sizeof(win)/(int)sizeof(win[0]);//此例中l(wèi)ength=3
while (status == OK)//標志位1,執(zhí)行死循環(huán)
{
srand((unsigned) time(&t));
i = rand() % 3 ;//srand和rand配合產(chǎn)生隨機數(shù)
computer = guess_arr[i];//將隨機數(shù)轉(zhuǎn)換為石頭剪刀或者布的字符串
computer_person[0] = computer;//將計算機的出拳結(jié)果放入*computer_person
do{
printf("請輸入 剪刀 石頭 布:\n");
scanf("%s",person);
if (strcmp(person,"god") == 0)//上帝模式,實現(xiàn)可看到電腦出拳結(jié)果
{
printf("*********************************\n");
printf("上帝你好,電腦本局的出的是 : %s \n",computer);
printf("*********************************\n");
continue;
}
else
printf("你輸入的是:%s\n", person);//下一行用于判斷用戶的輸入是否為石頭剪刀布
if ((strcmp(person,"石頭") == 0 )||(strcmp(person,"剪刀") == 0 )||(strcmp(person,"布") == 0 ))
break;//結(jié)果為石頭剪刀布之一,跳出循環(huán)。
else
printf("請檢查你的輸入是否為石頭剪刀或者布: \n");
}while(1);
computer_person[1] = person;
tcnt++;
if (strcmp(computer, person) == 0 )
{
printf("平手!\n\n");
}
else if (exist_in(win, computer_person, length))
{
printf("電腦獲勝\n\n");
dcnt++;
}
else
{
printf("玩家獲勝\n\n");
vcnt++;
nextround();
}
}
person = NULL;
computer = NULL;
free(person);
free(computer);
return 0;
}
/**********************************************
exist_in函數(shù)用于判斷是否是電腦獲勝,length為3,比較3次,arr1和arr2中字符串的
順序即可判斷出電腦是否獲勝。
*********************************************/
int exist_in(char *arr1[][2], char *arr2[], int length)
{
int i;
for (i = 0; i < length; i++)
{
if (strcmp(arr1[i][0], arr2[0]) == 0 && strcmp(arr1[i][1], arr2[1]) == 0)
{
return 1;
}
}
return 0;
}
void nextround (void)
{
int m = 0;
printf("請輸入指令:1退出,2繼續(xù),3數(shù)據(jù)總結(jié)\n");
scanf ("%d",&m);
switch (m)
{
case 1:
status = QUIT;
break;
case 2:
printf("新的一局開始\n");
break;
case 3:
printf("您的勝場數(shù)是%d,敗場數(shù)是%d,總場數(shù)是%d\n",vcnt,dcnt,tcnt);
status = QUIT;
break;
default:
printf("輸入錯誤退出");
status = QUIT;
break;
}
}
以上就是使用vc++實現(xiàn)的石頭剪刀布程序的全部代碼了,希望對大家學習VC++能夠有所幫助。
相關文章
C++線程優(yōu)先級SetThreadPriority的使用實例
這篇文章主要介紹了C++線程優(yōu)先級SetThreadPriority的使用實例,較為詳細的講述了C++線程及其優(yōu)先級的用法,需要的朋友可以參考下2014-10-10C語言動態(tài)規(guī)劃點殺dp算法LeetCode炒股習題案例解析
這篇文章主要介紹為了C語言動態(tài)規(guī)劃點殺dp算法,本文以LeetCode炒股習題案例來為大家進行詳細解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助2022-02-02C++11 學習筆記之std::function和bind綁定器
這篇文章主要介紹了C++11 學習筆記之std::function和bind綁定器,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2021-07-07C/C++實現(xiàn)HTTP協(xié)議解析的示例代碼
基本上,HTTP?是一種基于?TCP/IP?的通信協(xié)議,用于通過?Web?傳遞?HTML?文件、圖像文件、查詢結(jié)果等數(shù)據(jù)。本文將用C/C++實現(xiàn)HTTP協(xié)議解析,感興趣的可以了解一下2022-07-07