LeetCode解析------843.猜猜这个单词-极小化极大

题目:

这个问题是 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;
}

在这里插入图片描述

结语:
晚安!晚安!晚安!晚安!晚安!晚安!晚安!晚安!晚安!晚安!

猜你喜欢

转载自blog.csdn.net/weixin_44337475/article/details/106218824