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

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

Восстановить пароль Регистрация
Другие темы раздела
C++ Постройте несколько функций для запроса и чтения различного вида информации http://www.cyberforum.ru/cpp-beginners/thread895376.html
Использование библиотеки ввода-вывода языка С++ 3. Постройте несколько функций для запроса и чтения различного вида информации. Простейший пример - функция y_or_n() (Которая просит ввести Yes\No). Идеи: почтовый адрес, дата, личные данные и т.д. Постарайтесь сделать их защищенными от неправильного ввода.
C++ Объясните, как понять строчку в коде #include <stdio.h> #include <conio.h> #include <windows.h> #include <locale.h> #define M 1000 int versh, ves, nov_ves, zamk, n; int ne_zamk (int i, int n1){ //проверка на включение вершины в цикл http://www.cyberforum.ru/cpp-beginners/thread895373.html
C++ Программа печатает (1) все буквы в нижнем регистре, (2) все буквы, (3) все буквы и цифры, (4) все символы, которые могут встречаться в идентификаторах
Использование библиотеки ввода-вывода языка С++ 4. Напишите программу, которая печатает (1) все буквы в нижнем регистре, (2) все буквы, (3) все буквы и цифры, (4) все символы, которые могут встречаться в идентификаторах C++ на вашей системе, (5) все символы пунктуации
Реализуйте стандартную библиотеку ввода/вывода C C++
Использование библиотеки ввода-вывода языка С++ 5. Реализуйте стандартную библиотеку ввода/вывода C () с помощью стандартной библиотеки ввода/вывода C++ () (достаточно printf и scanf).
C++ Вывести строку на экран, но без маленьких букв http://www.cyberforum.ru/cpp-beginners/thread895368.html
22. Перегрузите операцию << для класса , который будет просить ввести любую строку, а затем должен опять вывести её на экран но без маленьких букв
C++ Реализуйте стандартные функции printf и cin так, чтобы они могли использоваться одновременно Использование библиотеки ввода-вывода языка С++ 15. Реализуйте стандартные функции printf(c помощью cout) и cin(с помощью scanf) так, чтобы они могли использоваться одновременно. подробнее

Показать сообщение отдельно
Ded_Vasilij
 Аватар для Ded_Vasilij
229 / 211 / 15
Регистрация: 01.09.2012
Сообщений: 2,103
08.06.2013, 16:06     однонаправленный список
Вот готовое, поправить пять минут работы, думаю сами справитесь
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;
    }
}
 
Текущее время: 17:12. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru