Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.63/140: Рейтинг темы: голосов - 140, средняя оценка - 4.63
 Аватар для v.a.l.i.d
425 / 390 / 113
Регистрация: 21.09.2012
Сообщений: 913

Самый простой односвязный список

09.12.2012, 23:29. Показов 27932. Ответов 10
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Здравствуйте. Найдите ошибки или помогите полностью написать самый простой односвязный список. Без классов, без шаблонов и без функций.

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
#include "stdafx.h"
#include "iostream"
using namespace std;
 
struct list
{
    long val;
    list *next;
} *slist;
 
int _tmain(int argc, _TCHAR* argv[])
{
    setlocale(LC_ALL, "Russian");
 
    int n;
 
    cout << "Введите число элементов: ";
    cin >> n;
 
    cout << "Введите элементы: " << endl;
    for (int i=0; i<n; i++)
    {
        cin >> slist->val;
        slist->next = new list;
        slist = slist->next;
    }
    cout << endl;
 
    system("pause");
    return 0;
}
После ввода первого элемента программа аварийно завершается
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
09.12.2012, 23:29
Ответы с готовыми решениями:

Самый самый самый простой пример рекурсии
приведите самый прост пример рекурсии)))void main(int k) { int n=10; k=n; k++; n=k; if(n!=20)main(n); ...

Сформировать список из 10 книг, используя динамическую структуру данных односвязный список
друзья спасайте Сформировать список из 10 книг, используя динамическую структуру данных односвязный список С++

Создать класс «Квартира», в котором список комнат реализовать как односвязный список
Добрый день,написал фот такой клас по заданию:Создать класс «Квартира», в котором список комнат реализовать как односвязный список....

10
 Аватар для Schizorb
512 / 464 / 81
Регистрация: 07.04.2012
Сообщений: 869
Записей в блоге: 1
10.12.2012, 07:45
Память под slist на первой итерации не выделена, куда происходит эта запись?
C++
1
cin >> slist -> val;
1
CEO SOVAZ Corp.
 Аватар для sovaz1997
386 / 232 / 51
Регистрация: 17.12.2011
Сообщений: 822
Записей в блоге: 1
10.12.2012, 08:07
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
#include "iostream"
using namespace std;
 
struct list
{
    long val;
    list *next;
} *slist;
 
int main()
{
    setlocale(0,"");
 
    int n;
 
    cout << "Введите число элементов: ";
    cin >> n;
 
    cout << "Введите элементы: " << endl;
    for (int i = 0; i < n; i++)
    {
        slist = new list;
        cin >> slist->val;
        slist->next = new list;
        slist = slist->next;
    }
    cout << endl;
 
    return 0;
}
1
 Аватар для Schizorb
512 / 464 / 81
Регистрация: 07.04.2012
Сообщений: 869
Записей в блоге: 1
10.12.2012, 08:20
sovaz1997, а теперь придумайте как напечатать элементы этого списка)
0
 Аватар для lemegeton
4903 / 2696 / 921
Регистрация: 29.11.2010
Сообщений: 5,783
10.12.2012, 08:28
Цитата Сообщение от v.a.l.i.d Посмотреть сообщение
самый простой односвязный список. Без классов, без шаблонов и без функций.
Это будет наоборот, сложный односвязный список. Классы, шаблоны и функции как раз упрощают работу со сложными структурами данных.
1
 Аватар для v.a.l.i.d
425 / 390 / 113
Регистрация: 21.09.2012
Сообщений: 913
10.12.2012, 12:21  [ТС]
Цитата Сообщение от Schizorb Посмотреть сообщение
а теперь придумайте как напечатать элементы этого списка)
ну для этого нужно чтобы было два указателя. один на предыдущий узел а другой на следующий )
C++
1
2
3
4
5
6
    struct list
    {
        int val;        // значение
        list *prev;     // указатель на предыдущий узел
        list *next;     // указатель на следующий узел
    } *slist;
по другому никак не напечатаешь. (я так думаю)

Добавлено через 5 минут
Все. Я понял как надо работать со списками. Даже небольшую программу написал с двусвязным списком. Все отлично работает Благодарю всех за помощь
2
 Аватар для Schizorb
512 / 464 / 81
Регистрация: 07.04.2012
Сообщений: 869
Записей в блоге: 1
10.12.2012, 12:23
Цитата Сообщение от v.a.l.i.d Посмотреть сообщение
ну для этого нужно чтобы было два указателя
Тогда это уже будет двусвязный список)

Тут на самом деле достаточно запомнить адрес первого элемента (head) и двигаться по элементам пока не встретится последний (у последнего элемента next = 0, то есть он ни на что не ссылается).

Добавлено через 1 минуту

Не по теме:

Цитата Сообщение от v.a.l.i.d Посмотреть сообщение
Даже небольшую программу написал с двусвязным списком
Код бы хоть выложил заценить, может кому пригодится)

0
 Аватар для v.a.l.i.d
425 / 390 / 113
Регистрация: 21.09.2012
Сообщений: 913
10.12.2012, 12:25  [ТС]
Цитата Сообщение от Schizorb Посмотреть сообщение
Код бы хоть выложил заценить, может кому пригодится)
вот: (можно сказать это моя первая работающая программа по спискам)
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
#include "stdafx.h"
#include "iostream"
using namespace std;
 
int _tmain(int argc, _TCHAR* argv[])
{
    setlocale(LC_ALL, "Russian");
 
    struct list
    {
        int val;        // значение
        list *prev;     // указатель на предыдущий узел
        list *next;     // указатель на следующий узел
    } *slist;
 
    // Создание списка из 3-х узлов
    
    // 1-ый узел
    slist = new list;               // создание
    slist->val = 10;                    // значение
    slist->prev = new list;
    slist->prev = NULL;             // нет предыдущего узла
 
    // 2-ой узел
    slist->next = new list;         // создание
    slist->next->prev = new list;
    slist->next->prev = slist;      // предыдущий узел - первый
    slist = slist->next;                // переход на этот узел
    slist->val = 20;                    // значение
    
    // 3-ий узел (последний)
    slist->next = new list;         // создание последнего узла
    slist->next->prev = new list;
    slist->next->prev = slist;      // предыдущий узел - второй узел
    slist = slist->next;                // переход на этот узел
    slist->next = NULL;             // конец списка
    slist->val = 30;                    // значение
 
    // печать значений во всех узлах с конца в начало. (сейчас находимся в конце узла)
    cout << slist->val << " ";      // 3
    slist = slist->prev;                // переход на второй узел
    cout << slist->val << " ";      // 2
    slist = slist->prev;                // переход на первый узел
    cout << slist->val << " ";
    cout << endl << endl;
 
    // печать с начала до конца с помощью цикла. (сейчас находимся в первом узле)
    while (slist != NULL)
    {
        cout << slist->val << " ";
        slist = slist->next;            // переход к следующему узлу
    }
    cout << endl << endl;
 
 
    system("pause");
    return 0;
}
0
 Аватар для Schizorb
512 / 464 / 81
Регистрация: 07.04.2012
Сообщений: 869
Записей в блоге: 1
10.12.2012, 12:32
Вот тут у тебя лишнее выделение памяти:
C++
1
slist->next->prev = new list;
Потом же идет присваивание:
C++
1
slist->next->prev = slist;
1
 Аватар для v.a.l.i.d
425 / 390 / 113
Регистрация: 21.09.2012
Сообщений: 913
10.12.2012, 12:45  [ТС]
Цитата Сообщение от Schizorb Посмотреть сообщение
Вот тут у тебя лишнее выделение памяти:
А в какой строчке?
0
 Аватар для Schizorb
512 / 464 / 81
Регистрация: 07.04.2012
Сообщений: 869
Записей в блоге: 1
10.12.2012, 12:51
Вот попытался изобразить что-то по твоему примеру, именно с односвязным списком. И лучше структуру все-таки именовать node, она же хранит инфо об одном узле, а не о списке.

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>
using namespace std;
 
int main()
{
    setlocale(LC_ALL, "Russian");
 
    struct node
    {
        int val;        // значение
        node *next;     // указатель на следующий узел      
    };
  
    node * head = 0; // хранит адрес головного узла
    node * curr = head;    // хранит адрес текущего узла
    
    int x;
    while(cin >> x)
    {
        if(!head)   // если головного узла нет
        {
            head = new node;               // создание головного узла            
            head->val = x;                 // значение
            head->next = NULL;            // нет следующего узла
            
            curr = head;                   // текущий узел
        }
        
        // если головной элемент есть
        else
        {
            curr->next = new node;         // создание узла
            curr = curr->next;            // переход на этот узел
            curr->val = x;                 // значение
            curr->next = NULL;             // конец списка    
        }
    }
    
 
    // печать с начала до конца с помощью цикла
    curr = head;
    while (curr != NULL)
    {
        cout << curr->val << " ";
        curr = curr->next;            // переход к следующему узлу
    }
    cout << endl << endl;
 
 
    return 0;
}
Завершить ввод Ctrl+Z (в Windows). И еще надо бы очистку памяти в конце сделать)

Добавлено через 1 минуту
Цитата Сообщение от v.a.l.i.d Посмотреть сообщение
А в какой строчке?
21, 26 и 33
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
10.12.2012, 12:51
Помогаю со студенческими работами здесь

Составить односвязный список на основе класса, объекты которого будут формировать этот список
Составить односвязный список на основе класса, объекты которого будут формировать этот список. В описание класса должны входить данные...

Односвязный список: заносить в новый список элементы исходного, которые больше заданного значения
Можете пожалуйста помочь в решении проблемы не. Не могу создать функцию которая будет с созданного заранее списка заносить в новый элементы...

Заменить массив структур на односвязный список, и на двусвязный список
Взять текст задания и заменить массив структур на односвязный список, и на двусвязный список using namespace std; class person { ...

Самый простой компилятор
В чём ошибка? Компилятор выдаёт ошибку. #include &lt;iostream&gt; using namespace std; using std:cout; using std::cin; ...

Создать двусвязный список групп факультета, где каждая группа представляет собой односвязный список студентов
Задание: создайте двусвязный список групп факультета. Каждая группа представляет собой односвязный список студентов. Помогите пожалуйста,...


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

Или воспользуйтесь поиском по форуму:
11
Ответ Создать тему
Новые блоги и статьи
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Access
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
Создание Single Page Application на фреймах
krapotkin 16.11.2025
Статья исключительно для начинающих. Подходы оригинальностью не блещут. В век Веб все очень привыкли к дизайну Single-Page-Application . Быстренько разберем подход "на фреймах". Мы делаем одну. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru