Jak zaktualizować wartość klucza std::map
po użyciu find
metody?
Mam mapę i deklarację iteratora taką jak ta:
map <char, int> m1;
map <char, int>::iterator m1_it;
typedef pair <char, int> count_pair;
Używam mapy do przechowywania liczby wystąpień znaku.
Używam Visual C ++ 2010.
map
dokumentacją dotyczącą różnych funkcji udostępnianych przezmap
.error: assignment of member 'std::pair<char* const, char*>::second' in read-only object
:(Użyłbym operatora [].
map <char, int> m1; m1['G'] ++; // If the element 'G' does not exist then it is created and // initialized to zero. A reference to the internal value // is returned. so that the ++ operator can be applied. // If 'G' did not exist it now exist and is 1. // If 'G' had a value of 'n' it now has a value of 'n+1'
Dzięki tej technice odczytanie wszystkich znaków ze strumienia i policzenie ich staje się naprawdę łatwe:
map <char, int> m1; std::ifstream file("Plop"); std::istreambuf_iterator<char> end; for(std::istreambuf_iterator<char> loop(file); loop != end; ++loop) { ++m1[*loop]; // prefer prefix increment out of habbit }
źródło
[]
po użyciufind
(nie sądzę, że był to twój zamiar).end()
iteratora jest niezdefiniowanym zachowaniem i nie musi generować plikuSIGSEGV
(az mojego doświadczenia wynika, że jest mało prawdopodobne).Możesz użyć
std::map::at
funkcji członkowskiej, zwraca ona referencję do zamapowanej wartości elementu identyfikowanego kluczem k.std::map<char,int> mymap = { { 'a', 0 }, { 'b', 0 }, }; mymap.at('a') = 10; mymap.at('b') = 20;
źródło
Jeśli znasz już klucz, możesz bezpośrednio zaktualizować wartość w tym kluczu za pomocą
m[key] = new_value
Oto przykładowy kod, który może pomóc:
map<int, int> m; for(int i=0; i<5; i++) m[i] = i; for(auto it=m.begin(); it!=m.end(); it++) cout<<it->second<<" "; //Output: 0 1 2 3 4 m[4] = 7; //updating value at key 4 here cout<<"\n"; //Change line for(auto it=m.begin(); it!=m.end(); it++) cout<<it->second<<" "; // Output: 0 1 2 3 7
źródło
Możesz też zrobić w ten sposób-
std::map<char, int>::iterator it = m.find('c'); if (it != m.end()) (*it).second = 42;
źródło
Możesz zaktualizować wartość, jak poniżej
auto itr = m.find('ch'); if (itr != m.end()){ (*itr).second = 98; }
źródło