Форум программистов, компьютерный форум CyberForum.ru

Сортировка std::list ошибка компиляции algorithm 3868 error C2784 - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ Использование множества set http://www.cyberforum.ru/cpp-beginners/thread1135056.html
Задача состоит в следующем: необходимо заполнить массив числами от 1 до 49 случайным образом так, чтобы числа не повторялись. Идея состояла в следующем: при каждой новой генерации числа проверяю, нету ли его в массиве с помощью метода count. Если нету, то добавляю число в массив. Если же во множестве такой элемент уже содержится, то перехожу к новой итерации, не увеличивая при этом индекс i. Вот...
C++ Code Blocks компилятор GCC: где найти учебник Скажите пожалуйста, где можно найти нормальный учебник для этого компилятора, а то большинство для Visual Stydio. http://www.cyberforum.ru/cpp-beginners/thread1135053.html
C++ Целочисленные массивы: чередование минимального и максимального элементов
Как в целочисленном массиве сделать ,чтобы чередовались сначала минимальный элемент ,а потом максимальный?
C++ Преобразование QString to char
Подскажите пожалуйста как преобразовать QString в char. я понимаю что чего то не хватает а вот чего не пойму item *Head = NULL; void MainWindow::on_pushButton_clicked() { QString str; char a; item *curritem; curritem = new item; a=ui->lineEdit->text();
C++ Дан массив. Выберите из него все элементы, которые встречаются в массиве наибольшее число раз http://www.cyberforum.ru/cpp-beginners/thread1135030.html
Дан массив A(M). Выберите из него все элементы, которые встречаются в массиве наибольшее число раз. Код есть, поможете доработать? нужно чтобы элементы массива были в диапазоне ±1000. а M - в диапазоне 2, 20. И нужно распечатать индексы этих элементов в порядке возрастания. Заранее благодарен. #include "stdafx.h" #include "conio.h" #include "iostream" using namespace std; int main()...
C++ Visual Studio странное поведение Почему данный код компилируется и работает в Visual Studio? Ведь мы берем ссылку от временного объекта. #include <iostream> using namespace std; class Class{ private: int a; подробнее

Показать сообщение отдельно
rcyn
13 / 9 / 2
Регистрация: 30.01.2014
Сообщений: 47
31.03.2014, 18:42     Сортировка std::list ошибка компиляции algorithm 3868 error C2784
Добрый день, есть пользовательский класс, с вектором в качестве контейнера всё работает хорошо. А вот со списком вылетает ошибка:
Кликните здесь для просмотра всего текста
1>------ Build started: Project: dummy, Configuration: Debug Win32 ------
1> Source.cpp
1>c:\program files (x86)\microsoft visual studio 11.0\vc\include\algorithm(3868): error C2784: ''unknown-type' std::operator -(std::move_iterator<_RanIt> &,const std::move_iterator<_RanIt2> &)' : could not deduce template argument for 'std::move_iterator<_RanIt> &' from 'std::_List_iterator<_Mylist>'
1> with
1> [
1> _Mylist=std::_List_val<std::_List_simple_types<Item>>
1> ]
1> c:\program files (x86)\microsoft visual studio 11.0\vc\include\xutility(1955) : see declaration of 'std::operator -'
1> c:\users\okamenshchykov\documents\visual studio 2012\projects\dummy\dummy\source.cpp(193) : see reference to function template instantiation 'void std::sort<std::_List_iterator<_Mylist>,ItemPredicate>(_RanIt,_RanIt,_Pr)' being compiled
1> with
1> [
1> _Mylist=std::_List_val<std::_List_simple_types<Item>>,
1> _RanIt=std::_List_iterator<std::_List_val<std::_List_simple_types<Item>>>,
1> _Pr=ItemPredicate
1> ]
1> c:\program files (x86)\microsoft visual studio 11.0\vc\include\xutility(1955) : see declaration of 'std::operator -'
1> c:\program files (x86)\microsoft visual studio 11.0\vc\include\xutility(1955) : see declaration of 'std::operator -'
1> c:\program files (x86)\microsoft visual studio 11.0\vc\include\xutility(1955) : see declaration of 'std::operator -'
1> c:\program files (x86)\microsoft visual studio 11.0\vc\include\xutility(1955) : see declaration of 'std::operator -'
1>c:\program files (x86)\microsoft visual studio 11.0\vc\include\algorithm(3868): error C2784: ''unknown-type' std::operator -(const std::reverse_iterator<_RanIt> &,const std::reverse_iterator<_RanIt2> &)' : could not deduce template argument for 'const std::reverse_iterator<_RanIt> &' from 'std::_List_iterator<_Mylist>'
1> with
1> [
1> _Mylist=std::_List_val<std::_List_simple_types<Item>>
1> ]
1> c:\program files (x86)\microsoft visual studio 11.0\vc\include\xutility(1234) : see declaration of 'std::operator -'
1> c:\program files (x86)\microsoft visual studio 11.0\vc\include\xutility(1234) : see declaration of 'std::operator -'
1> c:\program files (x86)\microsoft visual studio 11.0\vc\include\xutility(1234) : see declaration of 'std::operator -'
1> c:\program files (x86)\microsoft visual studio 11.0\vc\include\xutility(1234) : see declaration of 'std::operator -'
1> c:\program files (x86)\microsoft visual studio 11.0\vc\include\xutility(1234) : see declaration of 'std::operator -'
1>c:\program files (x86)\microsoft visual studio 11.0\vc\include\algorithm(3868): error C2784: ''unknown-type' std::operator -(const std::_Revranit<_RanIt,_Base> &,const std::_Revranit<_RanIt2,_Base2> &)' : could not deduce template argument for 'const std::_Revranit<_RanIt,_Base> &' from 'std::_List_iterator<_Mylist>'
1> with
1> [
1> _Mylist=std::_List_val<std::_List_simple_types<Item>>
1> ]
1> c:\program files (x86)\microsoft visual studio 11.0\vc\include\xutility(1041) : see declaration of 'std::operator -'
1> c:\program files (x86)\microsoft visual studio 11.0\vc\include\xutility(1041) : see declaration of 'std::operator -'
1> c:\program files (x86)\microsoft visual studio 11.0\vc\include\xutility(1041) : see declaration of 'std::operator -'
1> c:\program files (x86)\microsoft visual studio 11.0\vc\include\xutility(1041) : see declaration of 'std::operator -'
1> c:\program files (x86)\microsoft visual studio 11.0\vc\include\xutility(1041) : see declaration of 'std::operator -'
1>c:\program files (x86)\microsoft visual studio 11.0\vc\include\algorithm(3868): error C2676: binary '-' : 'std::_List_iterator<_Mylist>' does not define this operator or a conversion to a type acceptable to the predefined operator
1> with
1> [
1> _Mylist=std::_List_val<std::_List_simple_types<Item>>
1> ]
1>c:\program files (x86)\microsoft visual studio 11.0\vc\include\algorithm(3868): error C2780: 'void std::_Sort(_RanIt,_RanIt,_Diff)' : expects 3 arguments - 4 provided
1> c:\program files (x86)\microsoft visual studio 11.0\vc\include\algorithm(3668) : see declaration of 'std::_Sort'
========== Build: 0 succeeded, 1 failed, 0 up-to-date, 0 skipped ==========

код:
Кликните здесь для просмотра всего текста
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
#include <iomanip>
#include <iostream>
#include <fstream>
 
#include <string>
 
 
#include <vector>
 
#include <list>
#include <map>
#include <set>
 
#include <ctime>
 
#include <cmath>
#include <algorithm>
#include <numeric>
 
using namespace std;
 
//////////////////////////////////////////////////////////////////////////
 
struct Item
{
   Item(){};
   Item(const string &name, const int &id, const double &value)
      : m_name(name)
      , m_id(id)
      , m_value(value)
   {}
   friend istream& operator>>(istream &is, Item &item);
   string m_name;
   int m_id;
   double m_value;
};
 
istream& operator>>(istream &is, Item &item)
{
   is >> item.m_name;
   is >> item.m_id;
   is >> item.m_value;
 
   return is;
}
 
//////////////////////////////////////////////////////////////////////////
 
class ItemPredicate
{
public:
   enum sortByField
   {
      NAME = 0,
      ID = 1,
      VALUE = 2
   };
   enum sortOrder
   {
      ASCENDING = 0,
      DESCENDING = 1
   };
   ItemPredicate() : cond(NAME), ord(ASCENDING), strToCmp(""), intToCmp(0), doubleToCmp(0.0)
   {}
   ItemPredicate(sortByField field, sortOrder order)  : cond(field) , ord(order)
      , strToCmp(""), intToCmp(0), doubleToCmp(0.0)
   {}
   ~ItemPredicate(){}
 
   bool operator()(const Item &left, const Item &right);
   bool operator()(const Item &item);
 
   void setFieldToCompareBy(sortByField field);
   void setSortOrder(sortOrder order);
 
   void setNameToFind(const string &nameToCompareWith);
   void setIDtoFind(const int &idToCompareWith);
   void setValueToFind(const double &valueToCompareWith);
  
protected:
private:
   sortByField cond;
   sortOrder ord;
 
   string strToCmp;
   int intToCmp;
   double doubleToCmp;
};
 
bool ItemPredicate::operator()(const Item &left, const Item &right)
{
   bool ret = true;
 
   switch (cond)
   {
   case NAME:
      ret = ( (ord == ASCENDING) ? ( left.m_name < right.m_name ) : ( left.m_name > right.m_name ) );
      break;
 
   case ID:
      ret = ( (ord == ASCENDING) ? ( left.m_id < right.m_id ) : ( left.m_id > right.m_id ) );
      break;
 
   case VALUE:
      ret = ( (ord == ASCENDING) ? ( left.m_value < right.m_value ) : ( left.m_value > right.m_value ) );
      break;
 
   default:
      cout << "ItemPredicate::operator(const Item &, const Item &): Someting gone wrong..." << endl;
      break;
   }
 
   return ret;
}
 
bool ItemPredicate::operator()(const Item &item)
{
   bool ret = true;
 
   switch (cond)
   {
   case NAME:
      ret = ( item.m_name == strToCmp );
      break;
   case ID:
      ret = ( item.m_id == intToCmp );
      break;
   case VALUE:
      ret = ( item.m_value == doubleToCmp );
      break;
   default:
      cout << "ItemPredicate::operator(const Item &): Someting gone wrong..." << endl;
      break;
   }
   
   return ret;
}
 
void ItemPredicate::setFieldToCompareBy(sortByField field)
{
   cond = field;
}
 
void ItemPredicate::setSortOrder(sortOrder order)
{
   ord = order;
}
 
void ItemPredicate::setNameToFind(const string &nameToCompareWith)
{
   strToCmp = nameToCompareWith;
}
 
void ItemPredicate::setIDtoFind(const int &idToCompareWith)
{
   intToCmp = idToCompareWith;
}
 
void ItemPredicate::setValueToFind(const double &valueToCompareWith)
{
   doubleToCmp = valueToCompareWith;
}
 
//////////////////////////////////////////////////////////////////////////
 
int main()
{
 
//////////////////////////////////////////////////////////////////////////
 
   ifstream is("from.txt");
   istream_iterator<Item> ii(is);
   istream_iterator<Item> eos;
   
   list<Item> itemContainer(ii, eos);
   cout << "list filled, vi.size() == " << itemContainer.size() << endl;
   cout << "list before sort: " << endl;
   
   int i = 0;
   for (list<Item>::const_iterator p = itemContainer.begin(); p != itemContainer.end(); p++, i++)
   {
      cout << i << ": " << setw(15) << left
           << p->m_name << setw(10) << right 
           << p->m_id << setw(10) << right
           << p->m_value << endl;
   }
   
   ItemPredicate pred(ItemPredicate::NAME, ItemPredicate::ASCENDING);
   sort(itemContainer.begin(), itemContainer.end(), pred);
   cout << "\nlist after sort by name" << endl;   
   i = 0;
   for (list<Item>::const_iterator p = itemContainer.begin(); p != itemContainer.end(); p++, i++)
   {
      cout << i << ": " << setw(15) << left
         << p->m_name << setw(10) << right 
         << p->m_id << setw(10) << right
         << p->m_value << endl;
   }
 
return 0;
}

Помогите пожалуйста разобраться в чём дело.
Компилятор MS VSU 2012
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
Текущее время: 14:40. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru