题目给定一个偶数长度的字符串 s,并给出字符串「相似」的定义:若两个字符串中含有相同数目的元音字母,则这两个字符串「相似」。现在我们将给定字符串s 拆分成长度相同的两半,前一半表示为字符串 a,后一半为字符串 b,我们需要判断字符串 a 和 b 是否「相似」,那么我们只需要按照「相似」的定义统计字符串 a 和 b 中的元音字母的个数是否相等即可。
class Solution {
public:
bool halvesAreAlike(string s) {
string a = s.substr(0, s.size() / 2);
string b = s.substr(s.size() / 2);
string h = "aeiouAEIOU";
int sum1 = 0, sum2 = 0;
for (int i = 0; i < a.size(); i++) {
if (h.find_first_of(a[i]) != string::npos) {
sum1++;
}
}
for (int i = 0; i < b.size(); i++) {
if (h.find_first_of(b[i]) != string::npos) {
sum2++;
}
}
return sum1 == sum2;
}
};