How to Remove Vowels from a String in C++?
- 时间:2020-09-23 15:50:46
- 分类:网络文摘
- 阅读:87 次
Given a string S, remove the vowels ‘a’, ‘e’, ‘i’, ‘o’, and ‘u’ from it, and return the new string.
Example 1:
Input: “leetcodeisacommunityforcoders”
Output: “ltcdscmmntyfrcdrs”Example 2:
Input: “aeiou”
Output: “”S consists of lowercase English letters only.
1 <= S.length <= 1000
Loop and Remove
The usual approach will be looping the string and check each character. Ignore the vowels or otherwise push it to the result string.
1 2 3 4 5 6 7 8 9 10 11 12 | class Solution { public: string removeVowels(string S) { string s = ""; for (const auto &n: S) { if (string("aeiou").find(n) == string::npos) { s.push_back(n); // s += n; } } return s; } }; |
class Solution { public: string removeVowels(string S) { string s = ""; for (const auto &n: S) { if (string("aeiou").find(n) == string::npos) { s.push_back(n); // s += n; } } return s; } };
Using Modern C++ std::accumulate()
With the std::accumulate() in Modern C++ e.g. C++14, we need to pass the begin and end iterators, the initial value which is set to a mutable string/vector, and a accmulator function.
1 2 3 4 5 6 7 8 9 10 11 | class Solution { public: string removeVowels(string S) { return std::accumulate(begin(S), end(S), std::string{}, [](auto &a, auto &b) { if (string("aeiou").find(b) == string::npos) { return a + b; } return a; // b is vowel, ignore }); } }; |
class Solution { public: string removeVowels(string S) { return std::accumulate(begin(S), end(S), std::string{}, [](auto &a, auto &b) { if (string("aeiou").find(b) == string::npos) { return a + b; } return a; // b is vowel, ignore }); } };
It is worth pointing out that the “” in C++ is interpreted to char* by default, that is why we need to explicitly cast it to string type before using the find() method.
–EOF (The Ultimate Computing & Technology Blog) —
推荐阅读:How to Build a Popular, Trustworthy Blog 6 Simple Ways to Promote Your Blog The Secret to Writing More Compelling Blog Titles 5 Habits Of Highly Successful Bloggers 5 Ways to Connect Your Blog Content Writers Google’s Perfect World: A New Technical SEO Framework Boost the Visibility of Your Blog With In-Person Events Are Top 20 Witnesses Voting Each Other? Introducing Witness-voti How to Design a Browser History using Double-ended Queue (deque) SteemJs: How Many Witnesses are Running on 23.1?
- 评论列表
-
- 添加评论