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

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

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

Author24 — интернет-сервис помощи студентам
крашит при вставке последнего( с остальными вроде все норм
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
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
03.11.2015, 17:09
Ответы с готовыми решениями:

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

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

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

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

1
...
1906 / 1326 / 965
Регистрация: 12.02.2013
Сообщений: 2,172
03.11.2015, 18:56 2
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
03.11.2015, 18:56
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
03.11.2015, 18:56
Помогаю со студенческими работами здесь

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

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

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

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

Односвязный список: удалить элемент списка, если он чётный и следующий элемент отрицательный и нечётный
Здравствуйте. Задание на односвязные списки: удалить элемент списка, если он чётный и следующий...

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


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

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2024, CyberForum.ru