Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.67/3: Рейтинг темы: голосов - 3, средняя оценка - 4.67
 Аватар для anti-k
227 / 75 / 31
Регистрация: 17.07.2015
Сообщений: 774

односвязный список не вставляет последний элемент

03.11.2015, 17:09. Показов 618. Ответов 1
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
крашит при вставке последнего( с остальными вроде все норм
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
#include<iostream>
using namespace std;
struct A
{
    int key;
};
struct List
{
    A a;
    List*next;
};
void Init(List**begin)
{
    *begin = new List;
    A a[5] = { 10,20,30,40,50 };
    
    (*begin)->a = a[0];
    (*begin)->next = NULL;
 
    List*end = *begin;
    for (int i(1); i < 5; i++)
    {
        end->next = new List;
        end = end->next;
        end->a = a[i];
        end->next = NULL;
    }
 
}
void Print(List*p)
{
    List*print = p;
    while (print)
    {
        cout << print->a.key << "->";
        print = print->next;
    }
    cout << "NULL\n\n";
}
void Input(List**begin, A&a)
{   
    List*t = new List;
    t->a = a;
    if ((*begin)->a.key > a.key)
    {
        t->next = (*begin);
        (*begin) = t;
        return;
    }
    List*t1 = (*begin); 
    List*t2 = t1->next;
    while (t1)
    {
        
        if (t->a.key > t1->a.key&&t->a.key < t2->a.key)
        {
            t1->next = t;
            t->next = t2;
            return;
        }
        t1 = t2;
        t2 = t2->next;      
        
    }
    //t2->next = t;
    //t->next = NULL;
}
int main() {
    List*begin = NULL;
    A k{ 49 };
    Init(&begin);
    Print(begin);
    Input(&begin, k);
    Print(begin);
    system("pause");
    return 0;
}
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
03.11.2015, 17:09
Ответы с готовыми решениями:

В односвязный список добавляется последний нулевой элемент
Здравствуйте, такая проблема, почему-то в список добавляется последний нулевой элемент, в чем может быть трабл ? скрин Вот...

Односвязный список: удалить последний элемент равный 0
Удалить последний элемент однонаправленного списка равный 0.

Односвязный список, поменять местами элементы (максимальный и последний)
Дан не пустой односвязный список, в котором каждый элемент имеет тип: struct elem { int num; elem* next; } Написать функцию...

1
...
 Аватар для anmartex
1910 / 1329 / 966
Регистрация: 12.02.2013
Сообщений: 2,172
03.11.2015, 18:56
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
#include <iostream>
 
struct Data {
    int key;
 
    bool operator < (const Data& data) const {
        return key < data.key;
    }
};
 
struct List {
    Data data;
    List* next;
};
 
//-----------------------------------------------------------------------------
std::ostream& operator << (std::ostream& os, const Data& data) {
    os << "key:" << data.key;
    return os;
}
//-----------------------------------------------------------------------------
std::ostream& operator << (std::ostream& os, const List* list) {
    for (; list; list = list->next) {
        os << list->data << " ";
    }
    return os;
}
//-----------------------------------------------------------------------------
List* insert(List*& list, const Data& data) {
    if ((list == nullptr) || (data < list->data)) {
        List* node = new List();
        node->data = data;
        node->next = list;
        list = node;
    }
    else {
        insert(list->next, data);
    }
    return list;
}
//-----------------------------------------------------------------------------
List* init(const Data data[], unsigned size) {
    List* list = nullptr;
 
    while (size--) {
        insert(list, *data++);
    }
    return list;
}
//-----------------------------------------------------------------------------
 
int main() {
    List* list = init((Data[]){{20}, {10}, {30}}, 3);
 
    std::cout << list << std::endl;
 
    insert(list, {25});
 
    std::cout << list << std::endl;
 
    return 0;
}
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
03.11.2015, 18:56
Помогаю со студенческими работами здесь

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

Линейный односвязный циклический список с указателем на последний узел
Здравствуйте! При объявлении такого типа следует указывать только указатель на следующий элемент: type elptr = ^el; ...

Составить программу, которая вставляет в список L новый элемент F
всем привет помогите написать программу,буду очень благодарен.Вот условие: Составить программу, которая вставляет в список L новый элемент...

Описать процедуру, которая вставляет в список А новый элемент К1
через стек или очередь!!!! Описать процедуру, которая вставляет в список А новый элемент К1 перед первым вхождением элемента К, если К...

Составить программу, которая вставляет в список L новый элемент F
буду очень благодарен:Составить программу, которая вставляет в список L новый элемент F перед первым вхождением элемента E, если E входит в...


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

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Новые блоги и статьи
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