题目
给你两个字符串:ransomNote
和 magazine
,判断 ransomNote
能不能由 magazine
里面的字符构成。
如果可以,返回 true
;否则返回 false
。
magazine
中的每个字符只能在 ransomNote
中使用一次。
输入:ransomNote = "aa", magazine = "aab"
输出:true
思路
代码
#include <iostream>
#include <vector>
#include <unordered_map>
#include <string>
#include <algorithm>
using namespace std;
class Solution {
public:
bool canConstruct(string ransomNote, string magazine) {
if (ransomNote.size() > magazine.size()) {
return false;
}
vector<int> cnt(26);
for (auto& c : magazine) {
cnt[c - 'a']++;
}
for (auto& c : ransomNote) {
cnt[c - 'a']--;
if (cnt[c - 'a'] < 0) {
return false;
}
}
return true;
}
};
int main() {
string arr1;
string arr2;
getline(cin, arr1);
getline(cin, arr2);
Solution method;
//bool result;
cout << boolalpha << method.canConstruct(arr1, arr2);
}