uva 489 Hangman Judge

Posted daaavidliu

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了uva 489 Hangman Judge相关的知识,希望对你有一定的参考价值。

大意:
电脑想个单词,玩家来猜。
玩家输入一个个字母,若答案里有这个字母,则显示该单词中所有该字母。
最终目标是显示答案所有字母。
猜错7次,死;


注意特殊条件:
1.玩家不断重复错误的字母,只算一次猜错。
2.如果答案是ans,读入了ansjklzxcv,这种情况算win的。虽然后面错误了7次,但游戏已经在猜出ans时提前结束了。。。

#include<iostream> 
#include<cstdio>
#include<cstring>
#include<cstdlib>
using namespace std;

const int maxalp=26;
const int maxl=100;
bool unguessed[maxalp];
bool alreadygussedwrong[maxalp];
int cnt;
char ans[maxl],guess[maxl];
int rnd;
int la,lg;
int ungcnt;
bool lose=false;
bool chickenedout=false;
bool insguess=false;
int main()
{
    while(scanf("%d",&rnd))
    {
        if(rnd==-1)break;
        memset(unguessed,false,sizeof(unguessed));
        memset(alreadygussedwrong,false,sizeof(alreadygussedwrong));
        memset(ans,0,sizeof(ans));
        memset(guess,0,sizeof(guess));
        cnt=0;
        lose=false;
        chickenedout=false;
        insguess=false;
        ungcnt=0;    
        
        printf("Round %d\n",rnd);
        scanf("%s%s",ans,guess);
        la=strlen(ans);
        lg=strlen(guess);
        for(int i=0;i<la;i++)
        if(!unguessed[ans[i]-a])
        {
            unguessed[ans[i]-a]=true;
            ungcnt++;
        }
        for(int i=0;i<lg;i++)
        {
            int ch=guess[i]-a;
            if(unguessed[ch])
            {
                unguessed[ch]=false;
                ungcnt--;
            }
            else if(!alreadygussedwrong[ch])
            {
                cnt++;
                alreadygussedwrong[ch]=true;
            }
            if(!ungcnt)
            {
                printf("You win.\n");
                insguess=true;
                break;
            }  
            if(cnt==7)
            {
                printf("You lose.\n");
                lose=true;
                break;
            }
        }
        if(!lose&&!insguess)
            for(int i=0;i<maxalp;i++)
                if(unguessed[i])
                {
                    printf("You chickened out.\n");
                    chickenedout=true;
                    break;
                }
        if(!lose&&!chickenedout&&!insguess)
            printf("You win.\n");
    }

    return 0;
}

 

以上是关于uva 489 Hangman Judge的主要内容,如果未能解决你的问题,请参考以下文章

UVA 489-- Hangman Judge(暴力串处理)

UVa 489:Hangman Judge

uva 489 Hangman Judge

UVa 489 -- Hangman Judge

UVa 489 HangmanJudge --- 水题

uva489