神秘的集合迭代器行为

帕维尔

如果我使用输入“ 4 petr egor”编译并运行以下程序,则输出为“ 2 2 2”,但是由于某种原因,预期输出应为“ 2 1 2”,如果是第二个,则从底部开始,如果语句,如果我输出* iter则得到“ 2”,如果输出* charMap.begin()-> second.begin(),则得到“ 1”。为什么会这样呢?

#include <iostream>
#include <vector>
#include <string>
#include <set>
#include <map>
#include <algorithm>

using namespace std;

int hammingdist(const string& S, const string& T) {
    int count = 0;
    for (int i = 0; i < S.size(); ++i) {
        if (S[i] != T[i]) count++;
    }
    return count;
}

int main() {
int n;
string T, S;
cin >> n >> T >> S;

map<char, set<int>> charMap;
vector<int> diffVec;

for (int i = 0; i < S.size(); ++i) {
    if (T[i] != S[i]) diffVec.push_back(i);
}

for (int i = 0; i < diffVec.size(); ++i) {
    charMap[S[diffVec[i]]].insert(diffVec[i]);
    charMap[T[diffVec[i]]].insert(diffVec[i]);
}

auto removeIter = charMap.begin();
while (removeIter != charMap.end()) {
    if (removeIter->second.size() == 1) {
        auto toRemove = removeIter;
        ++removeIter;
        charMap.erase(toRemove);
        continue;
    }
    if (removeIter != charMap.end())
        ++removeIter;
}

if (charMap.empty()) {
    cout << hammingdist(S, T) << endl;
    cout << "-1 -1";
}
else if (charMap.size() == 1) {
    cout << hammingdist(S, T) - 1 << endl;
    auto iter = charMap.begin()->second.begin();
    cout << (*/*charMap.begin()->second.begin()*/iter) + 1 << ' ' << (*(++iter) + 1); // the problem is here
}
else if (charMap.size() >= 2) {
    cout << hammingdist(S, T) - 2 << endl;
    auto iter = charMap.begin()->second.begin();
    cout << ((*iter) ) << ' ' << (*(++iter) + 1);
}
}
帕维尔

事实证明,它先递增“ iter”,然后对其进行2次输出。改变这个:

cout << (*iter) + 1 << ' ' << (*(++iter) + 1);

对此:

cout << (*iter) + 1 << ' ';
++iter;
cout << (*iter) + 1;

修复。因此,总而言之,这是一个cout问题,而不是set迭代器。

本文收集自互联网,转载请注明来源。

如有侵权,请联系 [email protected] 删除。

编辑于
0

我来说两句

0 条评论
登录 后参与评论

相关文章