遊戲規則是這樣的:計算機想一個單詞讓你猜,你每次可以猜一個字母。 如果單詞裡有那個字母,所有該字母會顯示出來;如果沒有那個字母,則計算機會在一幅「劊子手」畫上填一筆。 這幅畫一共需要7筆就能完成,因此你最多隻能錯6次。 注意,猜一個已經猜過的字母也算錯。
在本題中,你的任務是編寫一個「裁判」程式,輸入單詞和玩家的猜測,判斷玩家贏了(You win.)、 輸了(You lose.)還是放棄了(You chickened out.)。 每組數據包含3行,第1行是遊戲編號(-1爲輸入結束標記),第2行是計算機想的單詞,第3行是玩家的猜測。 後兩行保證只含小寫字母。
樣例輸入:
1
cheese
chese
2
cheese
abcdefg
3
cheese
abcdefgij
-1
樣例輸出:
Round 1
You win.
Round 2
You chickened out.
Round 3
You lose.
#include<stdio.h>
#include<string.h>
int main()
{
char ans[21];
char gus[28];
int times,yes;
int chances = 7;
int win = 0;
int lose = 0;
scanf("%d",×);
while(times != -1)
{
printf("Round %d\n",times);
scanf("%s\n%s",ans,gus);
yes = 0;
win = 0,lose = 0,chances = 7;
for(int i = 0;i < strlen(gus);i ++)
{
int flag = 0;
for(int j = 0;j < strlen(ans);j ++)
{
if(ans[j] == gus[i])
{
yes ++;
flag = 1; //找到之後不退出,因爲有一個單詞有相同的字母
}
}
if(flag == 0)
{
chances --;
}
if(chances == 0)
{
lose = 1;
printf("You lose.\n");
break;
}
else if(yes == strlen(ans))
{
win = 1;
printf("You win.\n");
break;
}
}
if(win != 1 && lose != 1)
{
printf("You chickened out.\n");
}
scanf("%d",x);
}
return 0;
}
或
#include <stdio.h>
#include <string.h>
#define maxn 100
int win, lose,left,chance;
char s[maxn], s2[maxn];
void guess(char ch);
int main()
{
int rnd;
while(scanf("%d%s%s", &rnd, s,s2) == 3 && rnd != -1)
{
printf("Round %d:\n", rnd);
left = strlen(s);
chance = 7;
for(int i = 0; i < strlen(s2); i++)
{
guess(s2[i]);
if(win || lose)
break;
}
if(win)
printf("You win.\n");
else if(lose)
printf("You lose.\n");
else
printf("You chickened out.\n");
}
return 0;
}
void guess(char ch)
{
int bad = 1;
for(int i = 0; i < strlen(s); i++)
{
if(ch == s[i])
{
left--;
s[i]= ' ';
bad = 0;
}
if(bad)
chance--;
if(!chance)
lose = 1;
if(!left)
win = 1;
}
}