当前位置 : 主页 > 编程语言 > c语言 >

c# – 如何打印出元音最多的单词

来源:互联网 收集:自由互联 发布时间:2021-06-25
我得到了一个代码,它在一行中找到一个至少有3个不同元音的单词.问题是我不知道为什么它会超出范围. static string findword(string e){ char[] vowels = { 'a', 'e', 'i', 'o', 'u' }; char[] sk = { ' ', '.',
我得到了一个代码,它在一行中找到一个至少有3个不同元音的单词.问题是我不知道为什么它会超出范围.

static string findword(string e)
{
    char[] vowels = { 'a', 'e', 'i', 'o', 'u' };
    char[] sk = { ' ', '.', ',', '!', '?', ':', ';', '(', ')', '\t' };
     string word= "";
    string[] parts = e.Split(sk, StringSplitOptions.RemoveEmptyEntries);
        for (int i = 0; i < e.Length; i++)
        {
            if (parts[i].IndexOf(vowels[i]) >= 3)
            {
                word = parts[i];
            }
        }
    return word;
}

因此,对于e =“我今天要回家”它应该返回“今天”.

这是我的版本:

var e = "I was going home today";

        char[] vowels = { 'a', 'e', 'i', 'o', 'u' };
        char[] sk = { ' ', '.', ',', '!', '?', ':', ';', '(', ')', '\t' };
        string word = "";
        string[] parts = e.Split(sk, StringSplitOptions.RemoveEmptyEntries);
        var mostVowels = 0;

        for (int i = 0; i < parts.Length; i++)
        {
            var part = parts[i];
            var numberOfVowels = 0;
            foreach (var vowel in vowels)
            {
                if (part.Contains(vowel)) numberOfVowels++;
            }

            if (mostVowels < numberOfVowels)
            {
                mostVowels = i;
                word = part;
            }
        }
        return(word);

它遍历各个部分,然后另一个循环检查该部分是否包含每个元音.然后它检查这个单词是否优于以前的最佳单词.

请注意,这会返回’going’,因为它是带有两个元音的第一个单词.

另请注意,我使用’foreach’而不是正常for循环,这有助于避免许多常见错误.

这段代码可能更好,因为它只查找每个元音一次.像’Aardvark’这样的单词只会得1分.毫无疑问,使用LINQ和正则表达式这是一种非常简洁的方法,但希望这可以帮助你了解你的循环和数组出错的地方.

编辑:这是一个正则表达式& LINQ版本适合您:

var r = new Regex("(a|e|i|o|u)");
    var mostVowels = parts.Max(y => r.Matches(y).Count);
    var result = parts.First(x => r.Matches(x).Count == mostVowels);

正则表达式是寻找元音的助手.第一个查询计算每个单词中的元音数量并返回最大值.第二个用元音找到第一个单词.

网友评论