我们拿到每一个单词,放到 map 里面,如果再次遇到就 ++,最后遍历的时候看对应的出现值,如果是 1 就直接尾插 vector 即可。
class Solution {
public:
vector<string> uncommonFromSentences(string s1, string s2) {
unordered_map<string,int> m;
string s;
for(int i = 0;i<s1.size();)
{
if(s1[i] != ' ')
{
while(i<s1.size() && s1[i] != ' ' )
{
s += s1[i];
i++;
}
}
m[s]++;
s="";
i++;
}
for(int i = 0;i<s2.size();)
{
if(s2[i] != ' ')
{
while(i<s2.size() && s2[i] != ' ' )
{
s += s2[i];
i++;
}
}
m[s]++;
s="";
i++;
}
vector<string> v;
for(auto e:m)
{
if(e.second == 1)
{
v.push_back(e.first);
}
}
return v;
}
};
上面的一大串其实就是在找单词然后插入,因为考虑到 stringstream类 可能还有萌新不太会,这里没有使用。