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

Ошибка в односвязном списке

25.05.2019, 12:56. Показов 680. Ответов 4
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
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
#include "exception.cpp"
template <class item>
class List
{
    struct Element
    {
        item inf;
        Element *next;
        Element(item x) : inf(x), next(0)
        {
        }
    };
    Element *head;
    int size;
    Element *Find(int index)
    {
        if ((index < 1) || (index > size))
        {
            return NULL;
        }
        else
        {
            Element *cur = head;
            for (int i = 1; i < index; i++)
            {
                cur = cur->next;
            }
            return cur;
        }
    }
public:
    List() :head(0), size(0)
    {
 
    }
    ~List()
    {
        while (!Empty())
        {
            Remove(1);
        }
    }
    bool Empty()
    {
        return head == 0;
    }
    int GetLength()
    {
        return size;
    }
    item Get(int index)
    {
        if ((index < 1) || (index > size))
        {
            throw ListException("ListException: get - list error");
        }
        else
        {
            Element *r = Find(index);
            item i = r->inf;
            return i;
        }
    }
    void insert(int index, item data)
    {
        if ((index < 1) || (index > size + 1))
        {
            throw ListException("ListException: insert - list error");
        }
        else
        {
            Element *newPtr = new Element(data);
            size = GetLength() + 1;
            if (index == 1)
            {
                newPtr->next = head;
                head = newPtr;
            }
            else
            {
                Element *prev = Find(index - 1);
                newPtr->next = prev->next;
                prev->next = newPtr;
            }
        }
    }
    void Remove(int index)
    {
        if ((index < 1) || (index > size))
        {
            throw ListException("ListException: remove - list error");
        }
        else
        {
            Element *cur;
            --size;
            if (index == 1)
            {
                cur = head;
                head = head->next;
            }
            else
            {
                Element *prev = Find(index - 1);
                cur = prev->next;
                prev->next = cur->next;
            }
            cur->next = NULL;
            delete cur;
        }
    }
    void Print()
    {
        for (Element *cur = head; cur != NULL; cur = cur->next) 
        {
            out << cur->inf << ' ';
        }
        out << endl;
    }
};
Ошибка C3861 out: идентификатор не найден одн список c:\users\www\source\repos\project22\proj ect22\list.cpp 116
Ошибка C3861 out: идентификатор не найден одн список c:\users\www\source\repos\project22\proj ect22\list.cpp 118
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
25.05.2019, 12:56
Ответы с готовыми решениями:

Ошибка в односвязном списке
Помогите решить эти 2 проблемы C4101: NextNode: неиспользованная локальная переменная (в 118 строке) C4703: используется потенциально...

Ошибка в односвязном списке
#include&lt;iostream&gt; #include&lt;clocale&gt; using namespace std; #define DEBUG class Monom{ protected: int...

Ошибка с удалением элемента в односвязном списке
Здравствуйте! Вроде написал функцию удаления элемента в указанной позиции, но почему то не срабатывает. Где ошибка?Или если есть вариант...

4
 Аватар для Гайфи
21 / 13 / 7
Регистрация: 17.10.2015
Сообщений: 126
25.05.2019, 13:01
Это не в списке ошибка. Что за out в коде? Думаю, это не то, что было задумано.
За консольный вывод отвечает объект
C++
1
std::cout
Пример:
C++
1
2
3
using namespace std;
//...
cout << "Hello World" << endl;
Или
C++
1
std::cout << "String" << endl;
0
1 / 1 / 0
Регистрация: 22.12.2018
Сообщений: 58
25.05.2019, 13:13  [ТС]
out отвечает за файловый вывод
0
 Аватар для Гайфи
21 / 13 / 7
Регистрация: 17.10.2015
Сообщений: 126
25.05.2019, 13:20
Цитата Сообщение от _karnaval_ Посмотреть сообщение
out отвечает за файловый вывод
В коде выше он ни за что не отвечает. Он даже не объявлен.
Попробуй так:
C++
1
2
3
4
5
6
7
include <fstream>
using namespace std;
//...
ofstream out;
out.open("result.txt")
out << "..." << endl;
out.close();
0
1 / 1 / 0
Регистрация: 22.12.2018
Сообщений: 58
25.05.2019, 14:28  [ТС]
даже если я вместо out пишу cout у меня вызывается исключение
Сам код программы:
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
#include <iostream>
#include <fstream>
#include <string>
 
using namespace std;
 
#include "List.cpp"
 
ifstream in("input.txt");
ofstream out("output.txt");
 
int main() 
{
    List <int> first, second;
    int value;
 
    int min = INT_MAX;
    int max = INT_MIN;
 
    while (in >> value)
    {
        first.insert(first.GetLength(), value);
        if (value <= min)  min = value;
        if (value >= max)  max = value;
    }
 
    in.close();
 
    for (int i = 1; i <= first.GetLength(); i++)
    {
        if (first.Get(i) == min)
        {
            second.insert(second.GetLength(), max);
        }
        else if (first.Get(i) == max)
        {
            second.insert(second.GetLength(), min);
        }
        else
        {
            second.insert(second.GetLength(), first.Get(i));
        }
    }
 
    second.Print();
    first.~List();
    second.~List();
    out.close();
    system("pause");
    return 0;
}
В задании требуется создать односвязный список в котором минимальный и максимальный элемент должны были менятся местами.
Миниатюры
Ошибка в односвязном списке  
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
25.05.2019, 14:28
Помогаю со студенческими работами здесь

Remove_at() в односвязном списке
Привет. Не пойму как в данном(рабочем) коде, при удалении элемента посреди списка, предыдущему элементу дается указатель на следующий (то...

Поиск в односвязном списке
Добрый всем день. Знаю что тема неоднократно поднималась. Помогите реализовать поиск по односвязному списку. Сильно не пинайте, я только...

Конструктор в односвязном списке
В общем, я только начинаю разбираться в программировании, и у меня возник такой вопрос: как работает конструктор, а именно мне нужно...

Поиск и удаление в односвязном списке
Помогите с удаление элемента по ключу(номеру этажа). При удалении 2-го элемента в списке, удаляется вместе с 1-ым, но если удалять 3, то 2...

Поиск цикла в односвязном списке
есть односвязный список struct List { int value; struct List *next; } _list; требуется написать функцию bool...


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

Или воспользуйтесь поиском по форуму:
5
Ответ Создать тему
Новые блоги и статьи
моя боль
iceja 24.01.2026
Выложила интерполяцию кубическими сплайнами www. iceja. net REST сервисы временно не работают, только через Web. Написала за 56 рабочих часов этот сайт с нуля. При помощи perplexity. ai PRO , при. . .
Модель сукцессии микоризы
anaschu 24.01.2026
Решили писать научную статью с неким РОманом
http://iceja.net/ математические сервисы
iceja 20.01.2026
Обновила свой сайт http:/ / iceja. net/ , приделала Fast Fourier Transform экстраполяцию сигналов. Однако предсказывает далеко не каждый сигнал (см ограничения http:/ / iceja. net/ fourier/ docs ). Также. . .
http://iceja.net/ сервер решения полиномов
iceja 18.01.2026
Выкатила http:/ / iceja. net/ сервер решения полиномов (находит действительные корни полиномов методом Штурма). На сайте документация по API, но скажу прямо VPS слабенький и 200 000 полиномов. . .
Расчёт переходных процессов в цепи постоянного тока
igorrr37 16.01.2026
/ * Дана цепь(не выше 3-го порядка) постоянного тока с элементами R, L, C, k(ключ), U, E, J. Программа находит переходные токи и напряжения на элементах схемы классическим методом(1 и 2 з-ны. . .
Восстановить юзерскрипты Greasemonkey из бэкапа браузера
damix 15.01.2026
Если восстановить из бэкапа профиль Firefox после переустановки винды, то список юзерскриптов в Greasemonkey будет пустым. Но восстановить их можно так. Для этого понадобится консольная утилита. . .
Сукцессия микоризы: основная теория в виде двух уравнений.
anaschu 11.01.2026
https:/ / rutube. ru/ video/ 7a537f578d808e67a3c6fd818a44a5c4/
WordPad для Windows 11
Jel 10.01.2026
WordPad для Windows 11 — это приложение, которое восстанавливает классический текстовый редактор WordPad в операционной системе Windows 11. После того как Microsoft исключила WordPad из. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru