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

Однонаправленный список. Операции: удалить элемент из заданной позиции, добавить элемент в заданную позицию,проверка на неравенство - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Как проверить работает ли системный динамик на ноутбуке http://www.cyberforum.ru/cpp-beginners/thread1063333.html
в студии вставляю код, но не чего не слышно #include <windows.h> int main() { Beep(247, 500); Beep(417, 500); Beep(417, 500); Beep(370, 500); Beep(417, 500); ...
C++ Архивирование файлов Всем привет. Цель: сжать и запаролить файл (бинарный). Сейчас используется передача параметров в 7z.exe, запуск 7z производиться с помощью CreateProcess. Хочется избавиться от зависимостей в конечном... http://www.cyberforum.ru/cpp-beginners/thread1063322.html
C++ Проект
Всем привет!) Подкиньте идею какой проект можно сделать используя GTK+ и MVS2008.)) p.s. текстовые редакторы и шифрование не подходит( чтобы было очень интересное и простое)
Из первой строчки убрать слова, которые встречаются во второй C++
Пользователь вводит с клавиатуры 2 строки. Из первой строчки убрать слова, которые встречаются во второй. Например: 1:user,internet,soft,it 2:computer,test,soft,c++,user 3:internet,it Вот...
C++ Закомпелировать торрент файт с exe http://www.cyberforum.ru/cpp-beginners/thread1063307.html
Здравствуйте. Может я спрашиваю что то не то или не в том разделе, но мне нужно, сделать файл расширения exe, что при его открытии у пользователя запускался торрент(торрен клиент установленный у...
C++ Загрузка данных из БД. Как лучше реализовать работу со связанными данными И так здравствуйте, у меня есть вопрос, как лучше реализовать работу со связанными данными, т.е у нас есть основная структура и более 10 дочерних. struct sProperty { int db; int type; int... подробнее

Показать сообщение отдельно
Ded_Vasilij
231 / 213 / 15
Регистрация: 01.09.2012
Сообщений: 2,103
05.01.2014, 12:46
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
#ifndef L1_H
#define L1_H
struct List
{
    char* info;
    List* next;
};
 
struct ListError{};
 
void Destroy(List* &top);                       // освободить память
char* getAt(List* top, int i);                  // взять из списка
void insAt(List*& top, int i, char* str);       // вставить в список
void delAt(List*& top, int i);                  // удалить из списка
int getSize(List* top);                         // посчитать количество элементов
void L1_print(List* top);
#endif//L1_H
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
129
#include <iostream>
#include "L1.h"
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;
    }
}
1
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru