Форум программистов, компьютерный форум CyberForum.ru
Наши страницы

С++ для начинающих

Войти
Регистрация
Восстановить пароль
 
Miwa123
37 / 37 / 1
Регистрация: 16.04.2013
Сообщений: 317
Записей в блоге: 1
#1

однонаправленный список - C++

08.06.2013, 15:04. Просмотров 436. Ответов 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
point* make_point( int n)
{
point *begin,*posl;
posl=NULL;
int i;
for(i=0;i<n;i++)
{
if(posl==NULL)
{   
    posl=new point;
    begin=posl;
}
else
{
    cout<<"Введите имя "<<i<<" участника: ";
    cin>>posl->name;
    posl->next=new point;
    posl=posl->next;
}
}
cout<<"Введите имя "<<i<<" участника: ";
cin>>posl->name;
posl->next=NULL;
return begin;
}
вот так вот создаю.
как удалить теперь его? помогите!
0
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
08.06.2013, 15:04
Здравствуйте! Я подобрал для вас темы с ответами на вопрос однонаправленный список (C++):

Добавить в список элемент после элемента с заданным инф.полем [Однонаправленный список] - C++
Вообщем есть: Функция создание списка Функции вывода на экран Функция добавление элемента с номером k А нужно ввести...

однонаправленный список - C++
Помогиде дописать программу. Формируется однонаправленный список, заполняется (int). теперь надо как то передрать его и удалить все...

однонаправленный список - C++
Ребятушки милые мои :) Помогите решить задачу !!! Даны натуральное число n и однонаправленный список, содержащий действительные...

однонаправленный список - C++
Прошу помощи: 1.Написать функцию для создания списка. Функция может создавать пустой список, а затем добавлять в него элементы. ...

Однонаправленный Список - C++
Как написать ф-ю добавления в конец элемента в однонаправленном списке?

Однонаправленный список - C++
Задача:Создать линейный однонаправленный список из целых чисел.Вставить в список последний четный элемент после каждого нечетного элемента....

Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Ded_Vasilij
231 / 213 / 15
Регистрация: 01.09.2012
Сообщений: 2,103
08.06.2013, 16:06 #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
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
121
122
123
124
125
126
127
128
#include <iostream>
using namespace std;
 
void clear(List* &top)
{
    if (!top)
        return;
    List* p = 0;
    while (top)
    {
        p = top;
        top = top ->next;
        delete [] p->info;
        delete p;
    }
    top = 0;
}
void Destroy(List*& top)//разрушить 
{
    clear(top);
}
 
char* getAt(List* top, int i)//взять
{
    int size = getSize(top);
    if (i >= size || i < 0 )
    {
        throw ListError();
    }
    
    if (i == 0)
    {       
        return top->info;
    }
 
    List* p1 = top;
    for(int j = 0; j < i; j++)
    {
        p1 = p1->next;
    }
    return p1->info;
}
void insAt(List*& top, int i, char* str)//вставить эелемент на место i
{
    int size = getSize(top);
    if (i > size || i < 0 )
    {
        throw ListError();
    }
 
    List* p = 0;
    try
    {
        p = new List;
        p->info = new char[(int)strlen(str)+1];
        strcpy_s(p ->info, (int)strlen(str)+1,str);//копирование в инф часть
    }
    catch (bad_alloc e)
    {
        delete p;
        throw;
    }
    if(i == 0) 
    {
        p->next = top;
        top = p; 
    }
    else
    {
        List * p1 = 0;
        p1 = top;
        for(int j = 0; j < i-1; j++)
        {           
            p1 = p1 ->next;
        }
        p ->next = p1->next;
        p1->next = p;       
    }
}
void delAt(List*& top, int i)
{
    int size = getSize(top);
    if (i >= size || i < 0 )
    {
        throw ListError();
    }
    List* p1 = 0;
    List* p2 = 0;
    if (i == 0)
    {
        p1 = top;
        top = top->next;
        delete [] p1->info;
        delete p1;
        return;
    }
    
    p1 = top;
    for(int j = 0; j < i-1; j++)
    {
        p1 = p1->next;
    }
    p2 = p1->next;
    p1->next = p2->next;
    delete[] p2->info;
    delete p2;
}
 
int getSize(List* top)
{
    int size = 0;   
    while(top)
    {       
        top = top->next;
        size++;
    }
    return size;
}
 
void L1_print(List* top)
{
    List* p = top;
    while (p)
    {
        cout << p->info << endl;
        p = p->next;
    }
}
0
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
08.06.2013, 16:06
Привет! Вот еще темы с ответами:

однонаправленный список - C++
попалась веселая задачка. &quot;построить функцию преобразующую заданный однонаправленный список в аналогичный список где элементты...

Однонаправленный список - C++
Создать однонаправленную очередь с числами в диапазоне от –50 до +50. Удалить из очереди каждый второй элемент.В конце работы все очереди...

Однонаправленный список - C++
Организовать ввод в однонаправленный список. Узел списка состоит из двух полей: целое число и указатель. Необходимо удалить из списка...

однонаправленный список - C++
чем отличаеться point *p; p=new(point); от p=new point; ???


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

Или воспользуйтесь поиском по форуму:
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru