题目:
这个问题是 LeetCode 平台新增的交互式问题 。
我们给出了一个由一些独特的单词组成的单词列表,每个单词都是 6 个字母长,并且这个列表中的一个单词将被选作秘密。
你可以调用 master.guess(word) 来猜单词。你所猜的单词应当是存在于原列表并且由 6 个小写字母组成的类型字符串。
此函数将会返回一个整型数字,表示你的猜测与秘密单词的准确匹配(值和位置同时匹配)的数目。此外,如果你的猜测不在给定的单词列表中,它将返回-1。
对于每个测试用例,你有 10 次机会来猜出这个单词。当所有调用都结束时,如果您对 master.guess 的调用不超过 10 次,并且至少有一次猜到秘密,那么您将通过该测试用例。
除了下面示例给出的测试用例外,还会有 5 个额外的测试用例,每个单词列表中将会有 100 个单词。这些测试用例中的每个单词的字母都是从 ‘a’ 到 ‘z’ 中随机选取的,并且保证给定单词列表中的每个单词都是唯一的。
示例 1:
输入: secret = “acckzz”, wordlist =[“acckzz”,“ccbazz”,“eiowzz”,“abcczz”]
解释:
master.guess(“aaaaaa”) 返回 -1, 因为 “aaaaaa” 不在 wordlist 中.
master.guess(“acckzz”) 返回 6, 因为 “acckzz” 就是秘密,6个字母完全匹配。
master.guess(“ccbazz”) 返回 3, 因为 “ccbazz” 有 3 个匹配项。
master.guess(“eiowzz”) 返回 2, 因为 “eiowzz” 有 2 个匹配项。
master.guess(“abcczz”) 返回 4, 因为 “abcczz” 有 4 个匹配项。我们调用了 5 次master.guess,其中一次猜到了秘密,所以我们通过了这个测试用例。
简单介绍:
题目:猜猜这个单词
题目难度:困难
使用语言:C。
这道题来自leetcode题库的极小化极大标签。
解题思路:
首先看题、分析题意,我们可以明确1个关键点:
1.拥有10次机会,猜出秘密单词。
既然,我们已经分析出来题目的关键任务了,下面我们就可以开始思考实现了。
我们采用算法与数据结构的思路来剖析一下这题,
数据结构:
要实现对数据的操作,我们要先明确存储数据的数据结构。
该题的数据结构的作用:
1.score:用来保存可能是秘密单词的标记数字。
算法:
既然明确了我们的数据结构,我们就可以开始我们的算法分析了。
1.申请一个大小wordlistSize的整型数组,保存标记数字
2.把中间的字符串调整到首位
3.猜测单词,利用result=guess(master,wordlist[i])与compare(wordlist[i],wordlist[j])==result找到最有可能的单词
代码部分:
#include<stdio.h>
#include<stdlib.h>
#define MAX_TRIES 10
int compare(char *s1,char *s2);
void findSecretWord(char **wordlist,int wordlistSize,Master *master){
int i,j;
int round=0;//猜测次数
int result=0;//结果长度
int *score=(int *)calloc(wordlistSize,sizeof(int));
char *tmp;
int counter=0;
tmp=wordlist[0];
wordlist[0]=wordlist[wordlistSize/2];
wordlist[wordlistSize/2]=tmp;
for(round=0;round<MAX_TRIES;round++){
for(i=0;i<wordlistSize;i++){
if(score[i]==round){
result=guess(master,wordlist[i]);//猜测
for(j=0;j<wordlistSize;j++){//在单词表里面查找与密码单词返回结果相同的单词
if(score[j]==round&&i!=j&&compare(wordlist[i],wordlist[j])==result){
score[j]=round+1;//用单词j去猜测秘密单词
}
}
break;
}
}
}
}
int compare(char *s1,char *s2)
{
int result=0;
while(*s1){
if(*s1==*s2){
result++;
}
s1++;
s2++;
}
return result;
}
结语:
晚安!晚安!晚安!晚安!晚安!晚安!晚安!晚安!晚安!晚安!