如何解决C ++条件循环,独立计数器
我正在编写一些用于计算给定单词中元音数量的代码,我已经完成了一些碾磨代码,但是我想知道是否有可能沿着这些思路做些事情
bool isVowel(char inputcharacter) //Bool function to check the validity of a character as being a bool
{
set<char> Vowels{'a','e','i','o','u','A','E','I','O','U'}; //Pre-Makes a set of characters (Specifically Vowels) Used to check characters
if (Vowels.find(inputcharacter) != Vowels.end()) //if the character is found within the list,before the list's end,the return will be true (Theoreticle indexing element that extends beyond the "physical" list)
{
return true; //Returns a true value
}
return false; //Returns a false value else
}
int numVowels(string inputstring) //Vowelcounter function
{
int Contained_Vowels = 0; //Intializes the counter to be 0
for (char c : inputstring; (isVowel(c) == true); Contained_Vowels++);
return Contained_Vowels;
}
解决方法
您的特定问题的答案已在评论中给出。
我想添加一个替代方案,也许是更复杂的功能,实现为Lambda。因此,整个过程可以用一个语句完成。
请先查看代码:
#include <iostream>
#include <algorithm>
#include <string>
int main()
{
std::string test{"Hello World"};
auto numberOfVowels = [](const std::string&s) -> size_t
{return std::count_if(s.begin(),s.end(),[](const char c) { return (0x208222 >> (c & 0x1f)) & 1; });};
std::cout << numberOfVowels(test) << '\n';
return 0;
}
我知道以下内容将很难理解。无论如何,我都想显示它,因为它是“更现代的C ++”解决方案。
因此,我将首先考虑并开发一种算法,然后使用适当的C ++元素来实现它。
首先是算法。如果我们使用ASCII码对字母进行编码,则会看到以下内容:
我们看到大写和小写字母的ASCII码仅在低5位不同。因此,如果我们用0x1F屏蔽ASCII码,那么char c{'a'}; unsigned int x{c & 0x1F}
的值将在1到26之间。因此,我们可以为每个字母计算一个5位的值。如果现在将所有元音标记为1,我们可以构建一个由32位(无符号int)组成的二进制数,并在每个元音为真的位置上设置一个位。然后我们得到类似
Bit position
3322 2222 2222 1111 1111 1100 0000 0000
1098 7654 3210 9876 5432 1098 7654 3210
Position with vowels:
0000 0000 0010 0000 1000 0010 0010 0010
该数字可以转换为0x208222。如果现在我们想找出一个字母(无论大写还是小写)是元音,那么我们就从字符(C&1F)中屏蔽掉不必要的位并将二进制数向右移位置,如生成的字母代码所具有的。如果然后将位设置在LSB位置,则我们有一个元音。这知道已有几十年了。
啊哈。并不是那么容易,但是可以用于ASCII编码的字母。
接下来,我们创建一个Lambda,它将使用一个纯粹由字母组成的字符串并计算元音。
然后,我们使用现代C ++元素来计算所需的值:
请注意:
有一百万种可能的解决方案。每个人都可以做,他想要的。
有些人仍然更喜欢C风格的模式,而另一些人更喜欢用C ++编程
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。