Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.67/18: Рейтинг темы: голосов - 18, средняя оценка - 4.67
1 / 1 / 0
Регистрация: 25.02.2013
Сообщений: 36

deque iterator not dereferencable

07.04.2013, 12:02. Показов 4165. Ответов 15
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
итак
программа должна считывать из файла данные об автобусных маршрутах (имя водителя, номер маршрута и т.д.). После этого сортировать сложной сортировкой (сначала по №автобуса и затем по №маршрута). Затем удалить из контейнера указанного водителя (прописные и строчные буквы в именах не различать).
у меня написан функциональный объект для того, что сравнивать элементы дека с введенной фамилией. Ошибок на этапе компиляции нет, сортирует нормально, но после ввода фамилии выскакивает такая ошибка: "deque iterator not dereferencable"
Версия программы не оконательная, т.е. тут ничегоне удаляется, потому как на этапе проверки, то ли нашел find_if выскакивает вот эта ошибка

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
#include <iostream>
#include <fstream>
#include <deque>
#include <algorithm>
#include <functional>
#include <string>
#include <time.h>
using namespace std;
string ToLower (const string & a){
    string temp(a);
    for (int i=0;i<temp.length();i++)
    {
        if (temp[i]>='A' && temp[i]<='Z')
            temp[i]=tolower(temp[i]);
        else 
            if (temp[i]>='А' && temp[i]<='Я')
                temp[i]=_tolower(temp[i]);
    }
    return temp;
}
bool comp(const string & a, const string & b){
    return (ToLower(a)<ToLower(b));
}
struct way{
    int marsh;
    string Name;
    int aut;
    string Mark;
    friend ostream & operator <<(ostream & out,way & a)
    {
        out<<a.marsh<<" "<<a.Name<<" "<<a.aut<<" "<<a.Mark<<" ";
        return out;}
    bool operator ==(way &a )
    {
        return (ToLower(Name)==ToLower(a.Name));}
};
class pred{
    string s;
public:
    pred (const string & s):s(s){};
    bool operator () (const way & a){return (ToLower(a.Name)==ToLower(s));}
};
bool waycmp(const way & a, const way & b)
{
    if (a.aut<b.aut) return true;
    if (a.aut==b.aut)
        if (a.marsh<b.marsh)
            return true;
    return false;
}
int main ()
{
    setlocale (LC_ALL,".1251");
    ifstream in("input.txt");
    if (!in)
    {
        cout<<"Файл не найден"<<endl;
        in.close();
        return 0;}
    int n;
    in>>n;
    if (n<=0)
    {
        cout<<"Неверные данные в файле"<<endl;
        in.close();
        return 0;}
    deque<way> d(n);
    for (int i=0;i<n;i++)
    {
        in>>d[i].marsh>>d[i].Name>>d[i].aut>>d[i].Mark;}
    for (int i=0;i<n;i++)
        cout<<d[i]<<endl;
    cout<<endl;
    sort(d.begin(),d.end(),waycmp);
    cout<<"**********************************"<<endl;
    for (int i=0;i<n;i++)
        cout<<d[i]<<endl;
    cout<<endl;
    cout<<"Введите фамилию водитела, которого хотите удалить"<<endl;
    string name;
    cin>>name;
    deque<way>::iterator i;
    i=find_if(d.begin(),d.end(),pred(name));
    cout<<*i<<endl;
    return 0;
}
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
07.04.2013, 12:02
Ответы с готовыми решениями:

List iterator not dereferencable
list iterator not dereferencable -выбивает такую ошибку что делать? код не дописан знаю проблема в функции удаления ...

List iterator not dereferencable
Добрый день. Вот в таком маленьком коде возникает ошибка &quot;list iterator not dereferencable&quot;. Помогите пожалуйста найти решение данной...

Map/set iterator not dereferencable
Всем доброго времени суток. Суть задания в том, чтобы удалить повторы комбинаций чисел в multimap'e. Проблема в том, что появляется данная...

15
2904 / 1937 / 211
Регистрация: 05.06.2011
Сообщений: 5,725
07.04.2013, 12:25
input.txt-то приложи
0
1 / 1 / 0
Регистрация: 25.02.2013
Сообщений: 36
07.04.2013, 12:26  [ТС]
12
100 Новицкий 21 Маз
100 Лихач 22 Ман
123 Леонович 23 Камаз
101 Новицкий 21 Маз
101 Лихач 22 Ман
123 Леонович 23 Камаз
102 новицкий 21 маз
100 Иванов 22 Ман
123 Сидоров 23 Камаз
103 Новицкий 21 Маз
101 лихач 22 ман
123 Петров 23 Камаз
0
2904 / 1937 / 211
Регистрация: 05.06.2011
Сообщений: 5,725
07.04.2013, 13:50
Хм. Скомпилил. gcc (Gentoo 4.5.3-r2 p1.1, pie-0.4.7) 4.5.3. Вот протокол.

100 Новицкий 21 Маз
100 Лихач 22 Ман
123 Леонович 23 Камаз
101 Новицкий 21 Маз
101 Лихач 22 Ман
123 Леонович 23 Камаз
102 новицкий 21 маз
100 Иванов 22 Ман
123 Сидоров 23 Камаз
103 Новицкий 21 Маз
101 лихач 22 ман
123 Петров 23 Камаз

**********************************
100 Новицкий 21 Маз
101 Новицкий 21 Маз
102 новицкий 21 маз
103 Новицкий 21 Маз
100 Лихач 22 Ман
100 Иванов 22 Ман
101 Лихач 22 Ман
101 лихач 22 ман
123 Леонович 23 Камаз
123 Леонович 23 Камаз
123 Сидоров 23 Камаз
123 Петров 23 Камаз

Введите фамилию водитела, которого хотите удалить
лихач
101 лихач 22 ман

Может, не то, чего ты хотел, но и ошибок никаких. А ты какую фамилию вводил?
1
What a waste!
 Аватар для gray_fox
1610 / 1302 / 180
Регистрация: 21.04.2012
Сообщений: 2,733
07.04.2013, 13:53
Цитата Сообщение от mazukta26 Посмотреть сообщение
C++
1
2
i=find_if(d.begin(),d.end(),pred(name));
cout<<*i<<endl;
find_if может вернуть d.end(), поэтому надо что-нибудь вроде
C++
1
2
3
4
5
6
i = find_if(d.begin(), d.end(), pred(name));
if (i != d.end()) {
   cout << *i << endl;
} else {
   cout << "Не найдено" << endl;
}
1
1 / 1 / 0
Регистрация: 25.02.2013
Сообщений: 36
07.04.2013, 13:59  [ТС]
хм
у меня ошибка не исчезает
точнее, если учесть возможность возврата d.end(), то ошибки нет
но и не выводит ничего, стало быть, ничего и не находит

Добавлено через 1 минуту
но не может же быть, что в visual studio не находит ничего,а в gcc находит
0
What a waste!
 Аватар для gray_fox
1610 / 1302 / 180
Регистрация: 21.04.2012
Сообщений: 2,733
07.04.2013, 14:02
mazukta26, возможно tolower не понимает русский.
1
1 / 1 / 0
Регистрация: 25.02.2013
Сообщений: 36
07.04.2013, 14:06  [ТС]
tolower не понимает, а вот _tolower понимает)
0
What a waste!
 Аватар для gray_fox
1610 / 1302 / 180
Регистрация: 21.04.2012
Сообщений: 2,733
07.04.2013, 14:08
Цитата Сообщение от mazukta26 Посмотреть сообщение
C++
1
if (temp[i]>='А' && temp[i]<='Я')
Так вроде только с латинецей можно, возможно в этом проблема.
1
1 / 1 / 0
Регистрация: 25.02.2013
Сообщений: 36
07.04.2013, 14:09  [ТС]
опять же, должно работать, тут ведь сравнение по коду + в других программах работает)
0
What a waste!
 Аватар для gray_fox
1610 / 1302 / 180
Регистрация: 21.04.2012
Сообщений: 2,733
07.04.2013, 14:14
Вообщем, что то там внутри предиката не так, раз find_if так себя ведёт.

Добавлено через 4 минуты
Цитата Сообщение от mazukta26 Посмотреть сообщение
опять же, должно работать
Русские символы не обязаны идти по порядку в кодировке.
0
2904 / 1937 / 211
Регистрация: 05.06.2011
Сообщений: 5,725
07.04.2013, 14:32
Кстати, да, я-то в Линуксе запускал, доже не скажу навскидку, что там за кодировка.
0
1 / 1 / 0
Регистрация: 25.02.2013
Сообщений: 36
07.04.2013, 16:04  [ТС]
они действительно идут по порядку за исключением буквы Ё
0
2904 / 1937 / 211
Регистрация: 05.06.2011
Сообщений: 5,725
07.04.2013, 19:26
Кстати! В Винде ж две кодировки! Одна в графике, другая -- в текстовой сессии. Вполне возможно, у тебя фамилия корёжится.
Попробуй записать фамилию в текстовый файл и программу запустить примерно так:
Bash
1
test < fam.txt
Если сработает, значит, дело в этом.
0
1 / 1 / 0
Регистрация: 25.02.2013
Сообщений: 36
07.04.2013, 21:47  [ТС]
я не очень понимаю, что нужно сделать Т_Т
0
2904 / 1937 / 211
Регистрация: 05.06.2011
Сообщений: 5,725
08.04.2013, 04:09
А жаль. Командную строку лучше знать. Почитай, тут не объяснишь.
Смысл, ещё раз повторюсь, может оказаться в том, что программу ты пишешь в одной кодировке, а фамилию
Цитата Сообщение от mazukta26 Посмотреть сообщение
C++
79
80
81
cout<<"Введите фамилию водитела, которого хотите удалить"<<endl;
string name;
cin>>name;
в другой. Попробуй, как введёшь, сразу вывести в cout.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
08.04.2013, 04:09
Помогаю со студенческими работами здесь

map/set iterator not dereferencable
map&lt;string,int&gt; optimized(map&lt;string,int&gt;&amp;dict){ map&lt;string,int&gt;::iterator i=dict.begin(); map&lt;string,int&gt;::iterator j=dict.begin(); ...

Ошибка list iterator not dereferencable
Ошибка при использовании итератора. Хэлп, сос :cry: void client_login(list&lt;client&gt; client_list) { char name, login, password,...

Map/set!( iterator not dereferencable)
Есть функция,в которой происходит поиск в map по ключу. Если по данному ключу нет значения, то необходимо провести интерполяцию двух...

Map/set iterator not dereferencable
Есть два класса, первый: class AnimationManager { public: String currentAim; std::map&lt;String, Animation&gt; animList; ...

Ошибка Expression: map/set iterator not dereferencable
Здравствуйте! Мне нужно вывести контейнер map в обратном порядке. Делаю следующим образом: for (multimap&lt;double, int&gt;::iterator i...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
16
Ответ Создать тему
Новые блоги и статьи
Знаешь почему 90% людей редко бывают счастливыми?
kumehtar 14.04.2026
Потому что они ждут. Ждут выходных, ждут отпуска, ждут удачного момента. . . а удачный момент так и не приходит.
Фиксация колонок в отчете СКД
Maks 14.04.2026
Фиксация колонок в СКД отчета типа Таблица. Задача: зафиксировать три левых колонки в отчете. Процедура ПриКомпоновкеРезультата(ДокументРезультат, ДанныеРасшифровки, СтандартнаяОбработка) / / . . .
Настройки VS Code
Loafer 13.04.2026
{ "cmake. configureOnOpen": false, "diffEditor. ignoreTrimWhitespace": true, "editor. guides. bracketPairs": "active", "extensions. ignoreRecommendations": true, . . .
Оптимизация кода на разграничение прав доступа к элементам формы
Maks 13.04.2026
Алгоритм из решения ниже реализован на нетиповом документе, разработанного в конфигурации КА2. Задачи, как таковой, поставлено не было, проделанное ниже исключительно моя инициатива. Было так:. . .
Контроль заполнения и очистка дат в зависимости от значения перечислений
Maks 12.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2. Задача: реализовать контроль корректности заполнения дат назначения. . .
Архитектура слоя интернета для сервера-слоя.
Hrethgir 11.04.2026
В продолжение https:/ / www. cyberforum. ru/ blogs/ 223907/ 10860. html Знаешь что я подумал? Раз мы все источники пишем в голове ветки, то ничего не мешает добавить в голову такой источник, который сам. . .
Подстановка значения реквизита справочника в табличную часть документа
Maks 10.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2. Задача: при выборе сотрудника (справочник Сотрудники) в ТЧ документа. . .
Очистка реквизитов документа при копировании
Maks 09.04.2026
Алгоритм из решения ниже применим как для типовых, так и для нетиповых документов на самых различных конфигурациях. Задача: при копировании документа очищать определенные реквизиты и табличную. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru