本题还是利用字符串匹配,根据题目意思如果匹配的字符错误次数超过7次,就会输。所以本题可以利用变量计算统计共出现错误的次数即可。
#include <stdio.h>
#include <string.h>
#define maxn 100
int left, chance;
char s[maxn], s2[maxn];
int win, lose;//flag数组
void guess(char ch)
{
int bad = 1;
for(int i = 0; i < strlen(s); i++)
if(s[i] == ch)//匹配成功将该位置的字符置为空
{
left--;
s[i] = ' ';
bad = 0;
}
if(bad)//未匹配到bad为1
--chance;
if(!chance)//当chance变量为0时
lose = 1;
if(!left)//当left变量为0时
win = 1;
}
int main()
{
int rnd;
while(scanf("%d%s%s", &rnd, s, s2) == 3 && rnd != -1)
{
printf("Round %d\n", rnd);
win = lose = 0;
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;
}

本文介绍了一个基于字符串匹配的游戏实现方案,玩家需要通过猜测字符来揭示隐藏的字符串,每猜错一次减少一次机会,总计最多允许猜错7次。文章提供了一个完整的C语言实现示例,包括如何统计错误次数及判断游戏胜负。
1659

被折叠的 条评论
为什么被折叠?



