С приведенным ниже кодом, я пытаюсь обновить значения в наборе, но не компилировать, когда пытаюсь скомпилировать.Изменение элементов набора
Это дает мне ошибку внизу, не могли бы вы помочь?
Что я здесь делаю?
#include <iostream>
#include <set>
using namespace std;
class A
{
public:
int a,b;
bool operator()(A a1,A a2)
{
return true;
}
A(int a ,int b)
{
this.a=a;
this.b=b;
}
};
void print_set(const std::set<A>&st) const
{
std::set<A>::iterator it;
std::cout<<"\nvalues in set";
for(it=st.begin();it!=st.end();it++)
{
std::cout<<"\na="<<it->a<<"b="<<it->b;
}
}
int main()
{
std::set<A> s;
for (int i=0;i<5;i++)
{
s.insert(A(i,i+1));
}
print_set(s);
std::set<A>::iterator it;
for(it=s.begin();it!=s.end();it++)
{
A tmp=*it;
s.erase(it);
tmp.a=10;
tmp.b=20;
s.insert(tmp);
std::cout<<"\ninserting tmp "<<tmp.a<<" "<<tmp.b;
}
print_set(s);
return 0;
}
Я получаю сообщение об ошибке, как это:
/usr/include/c++/4.6/bits/stl_function.h: In member function ‘bool std::less<_Tp>::operator()(const _Tp&, const _Tp&) const [with _Tp = A]’:
/usr/include/c++/4.6/bits/stl_tree.h:1277:4: instantiated from ‘std::pair<std::_Rb_tree_iterator<_Val>, bool> std::_Rb_tree<_Key, _Val, _KeyOfValue, _Compare, _Alloc>::_M_insert_unique(const _Val&) [with _Key = A, _Val = A, _KeyOfValue = std::_Identity<A>, _Compare = std::less<A>, _Alloc = std::allocator<A>]’
пожалуйста также опубликовать сообщение об ошибке, дикое предположение, хотя: я Не уверен, что вы можете объявить функцию как const, если она не является функцией класса, а итератору в цикле for требуется объявление типа, префиксное к нему. – mtijn
Наборы - это контейнеры, которые хранят уникальные элементы в соответствии с определенным заказом. По умолчанию они используют 'operator <' для сравнения элементов, поэтому вам нужно определить 'operator <' for you 'class A' –
Это не все сообщение об ошибке. Этот фрагмент только говорит, где ошибка. Он не говорит, что такое ошибка. Подсказка: фактическая ошибка содержит слово «ошибка». Постарайтесь прочитать и понять это. –