236A - Boy or Girl In this problem we have to find out if the number of distinct characters in one's user name is odd or even. How to count the unique characters in a string in c++? TIA.
# | User | Rating |
---|---|---|
1 | jiangly | 4039 |
2 | tourist | 3841 |
3 | jqdai0815 | 3682 |
4 | ksun48 | 3590 |
5 | ecnerwala | 3542 |
6 | Benq | 3535 |
7 | orzdevinwang | 3526 |
8 | gamegame | 3477 |
9 | heuristica | 3357 |
10 | Radewoosh | 3355 |
# | User | Contrib. |
---|---|---|
1 | cry | 168 |
2 | -is-this-fft- | 165 |
3 | atcoder_official | 160 |
3 | Um_nik | 160 |
5 | djm03178 | 157 |
6 | Dominater069 | 156 |
7 | adamant | 153 |
8 | luogu_official | 152 |
9 | awoo | 151 |
10 | TheScrasse | 147 |
236A - Boy or Girl In this problem we have to find out if the number of distinct characters in one's user name is odd or even. How to count the unique characters in a string in c++? TIA.
Name |
---|
Sort the vector (call this vector v)
Then use v.erase(unique(v.begin(), v.end()), v.end());
Then your answer is just the size of the vector afterwards.
Read about erase and unique to understand what they do.
Alternatively you could insert all the elements in a set and return it's size
If you are interested only in the count of unique characters of a string
x
, it suffices to do the following:can you describe it please?
Check this out. (sorting is necessary to get all similar characters in a continuous segment)
I have understood the sorting. But i can't understood this: unique(x.begin(), x.end()) — x.begin();
Unique return iterator to last character. Unique — begin would give the index of last character which is also the number of unique characters in the string.
Anyway I think using a bucket is better than sorting and unique() since we only have lowercase Latin letters.
One-liner if you're really lazy:
set(s.begin(), s.end()).size()