现在我正在开发一套文字游戏作为教我自己的方法(并重新创建一些我最喜欢的文字游戏!)在“实际”学习的编程朋友的帮助下,我们实现了一个很好的排列方法在我的一个课程中。它正在查找3个字母及以上的所有排列,并将它们与我所包含的字符串列表进行比较,其中包含了Scrabble锦标赛单词列表。
这就是背景,这是我当前的问题:我现在已经拥有了所有的排列,并将它们与现有单词进行了比较,并创建了一个新的List,其中包含给定字符串中所有可能的单词组合。但是,当我向用户提供此字符串时,我需要对其进行加扰。我找到了Fisher-Yates shuffle的一些C#实现,但我没有成功地使它们接受单个字符串(编辑:Fisher-Yates问题用char []数组解决)。然后我有了一个黑客的想法 - 为什么不使用一个相同长度的排列,但是!=原始单词。
不幸的是,每当我的条件语句向后返回单词时。最终用户并没有那么难以理解:)这是我的加扰代码:
// permWords is a Dictionary<int, List<string>>
String strScrambled= "";
foreach (List<string> listWords in permWords.Values)
{
foreach (string word in listWords)
{
if (word.Length == strWord.Length && word != strWord)
{
strScrambled = word;
}
}
}
我已经尝试过strScrambled = word + 1
,假设第一个不等于原始的排列是向后的单词。但是,我不认为在这种情况下真的“有效”;特别是考虑到它仍然返回相同的后退词。
对于如何使用char数组修复Fisher-Yates的问题,有一个非常有用的答案,但我仍然很想知道如何最好地使用我发布的内容,只找到一种方法来确保答案不仅仅是拼写单词。我对这种方法很感兴趣,因为排列列表已经存在;我想把它作为我的解决方案。
答案 0 :(得分:3)
我想你已经有了一个可以进行改组的方法:
void FisherYatesShuffle(char[] elements)
{
int N = elements.Count;
for(int i = 0; i<N-1; i++)
{
// exchange elements[i] with a random element in i+1 .. N
}
}
您需要做的就是将您的字符串转换为CharArray,然后将结果转换回字符串:
string shuffle(string input)
{
var arr = input.ToCharArray();
FisherYatesShuffle(arr);
return new String(arr);
}
答案 1 :(得分:1)
看看这对你有用......
string str = "hello";
// The random number sequence
Random num = new Random();
string rand = str;
while (rand == str)
rand = new string(str.OrderBy(s => (num.Next())).ToArray());
如果你想确保洗牌后的值不是完全相反的话,你可以将while条件改为......
while (rand == str || rand == str.Reverse())