劊子手遊戲(Hangman Judge)

2020-08-10 19:58:46

遊戲規則是這樣的:計算機想一個單詞讓你猜,你每次可以猜一個字母。 如果單詞裡有那個字母,所有該字母會顯示出來;如果沒有那個字母,則計算機會在一幅「劊子手」畫上填一筆。 這幅畫一共需要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;
 }
}