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

Линейные списки. База данных. - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ reinterpret_cast http://www.cyberforum.ru/cpp-beginners/thread255471.html
Подскажите плиз, чем отличается функция reinterpret_cast от static_cast? небольшой пример: const int MAX = 100; // размер буфера int buff; // буфер для целых чисел int main() { for(int j=0; j<MAX; j++) // заполнить буфер данными buff = j; // (0, 1, 2, ...) // создать выходной поток
C++ Ханойские башни Легенда гласит,что где-то в Ханое находится храм,в котором размещеа следущая конструкция:на основании укреплены 3 алмазных стержня,на один из которых при сотворении мира Брахиа нанизал 64 золотых диска с отверстием посередине,причем оказался самый большой диск,на нем-чут меньший и так далее,пока на верхушке пирамиды не оказался самый маленький диск.Жреца храма обязаны перекладывать диски по... http://www.cyberforum.ru/cpp-beginners/thread255470.html
C++ Написать функцию, которая определяет количество вхождений в СПИСОК елемента, заданого пользователем.
Ребята помогите пожалуйста, срочно надо!!!!!! Есть програма, но надо что бы она работала со списками!!!! Вот задание: Написать функцию, которая определяет количество вхождений в СПИСОК елемента, заданого пользователем. Вот програма: #include <stdio.h> #include <iostream.h> #include <conio.h> #define N 100
Функция fseek C++
Здраствуйте! Пишу сейчас телефонную книгу. Точнее что-то наподобие этого. Появилась проблема. Мне необходимо из файла, в который раннее были поблочно занесены контакты, прочитать контакт с заданным номером(порядковым). Чтобы узнать кол-во байт, на которое необходимо передвинуть указатель использую цикл, в котором складываю размеры елементов массива(из которого раннее производилась запись в...
C++ Найти в каждой строке наибольший элемент и поменять его местами с элементом главной диагонали http://www.cyberforum.ru/cpp-beginners/thread255405.html
Двумерные массивы, условие в заголовке! Заранее спасибо)
C++ Удобнее Подскажите пожалуйста билдер для С, чтобы удобнее был (вот на паскале, например, я использовал не TurboPascal, а Pascal ABC) подробнее

Показать сообщение отдельно
pusser
 Аватар для pusser
1 / 1 / 0
Регистрация: 17.10.2010
Сообщений: 77
11.03.2011, 16:38     Линейные списки. База данных.
Помагите плиз посмотреть в чём ошибки, не могу понять как их исправить.

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
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
/*База данных компьютерных игр,
в которой каждая игра характеризуется названием, годом выхода, ограничением по возрасту и жанром
 
1.  Добавление новой записи
2.  Удаление произвольной записи по ее номеру
3.  Поиск записей по некоторому полю
4.  Печать всех записей */
 
 
# include <iostream>
# include <string>
 
using namespace std;
const int MaxCh = 21;
const int MaxName = 21;
 
struct GameS
{
    GameS* next;
    GameS* prev;
    char NameGame[MaxName];
    int Year;
    int Age;
    char Genre[MaxCh];
};
 
void Add (char *NameGame[], int YearV, int AgePlus, char *Genre[], GameS *&pbeg, GameS *&pend)
{
    GameS *q = new GameS;
    strcpy (q -> NameGame, NameGame);
    q -> Year = YearV;
    q -> Age = AgePlus;
    strcpy (q -> Genre, Genre);
    q -> prev = NULL;
    if (pbeg != NULL)
    {
        q -> next = pbeg;
        pbeg -> prev = q;
        pbeg = q;
    }
    else
    {
        q -> next = NULL;
        pbeg = pend = q;
 
    }
}
 
void Remove(int index, GameS *&pbeg, GameS *&pend)
{
    GameS *p = pbeg;
    for(int i = 0; i < index && p != NULL; i++)
    {
        p = p -> next;
    }
    if (p == NULL)
    {
        cout << "Элемент не найден" << endl;
        return;
    }
    if (p -> prev != NULL)
    {
        p -> prev -> next = p -> next;
    }
    else
    {
        pbeg = p -> next;
    }
    if (p -> next != NULL)
    {
        p -> next -> prev = p -> prev;
    }
    else
    {
        pend = p -> prev;
    }
    delete p;
}
 
GameS* Search(GameS *pbeg, GameS *pend, int key)
{
    GameS *p = pbeg;
    while (p != NULL)
    {
        if (p -> Year == key)
        {
            break;
        }
        p = p -> next;
    }
 
    return p;
}
 
void Print(GameS *pbeg, GameS *pend)
{
    GameS *p = pbeg;
    cout << "Название\tГод выпуска\tОграничения по возрасту\tЖанр"<<endl;
    while (p!=NULL)
    {
        cout << p -> NameGame << "\t" << p-> Year << "\t" << p -> Age << "\t" << p -> Genre << endl;
        p = p -> next;
 
    }
    cout << endl;
}
 
 
 
int main()
{
    setlocale (LC_ALL,"Rus");
    int UserChoise;
    GameS *pbeg = NULL;
    GameS *pend = NULL;
    do 
    {
        cout << endl;
        cout << "          Меню" << endl;
        cout << "=========================" << endl;
        cout << " [1] Добавить игры" << endl;
        cout << " [2] Удалить игру" << endl;
        cout << " [3] Найти игру по возрастному ограничению" << endl;
        cout << " [4] Показать все игры" << endl;
        cout << " [5] Выход" << endl;
        cout << "=========================" << endl;
        cout << endl;
        cout << "Ваш выбор : "; cin >> UserChoise;
 
        switch (UserChoise)
        {
            case 1: 
                int YearV,AgePlus;
                char NameGame[21], Genre[21];
                cout << "Введите название игры: " << endl; cin.getline (NameGame, sizeof(NameGame));
                cout << "Год выпуска игры: " << endl; cin >> YearV;
                cout << "Ограничения по возрасту: " << endl; cin >> AgePlus;
                cout << "Жанр игры: " << endl; cin.getline (Genre, sizeof(Genre));
                Add (NameGame, YearV, AgePlus, Genre, pbeg, pend);
                break;
            case 2:
                int num;
                cout << "Введите индекс игры: "; cin >> num;
                Remove(num, pbeg, pend);
                break;
            case 3:
                int age_p;
                cout << "Введите возрастное ограничение: "; cin >> age_p;
                GameS *find = Search (pbeg, pend, age_p);
                if (find)
                {
                    cout << find -> NameGame << "\t" << find -> Year<< "\t" << find -> Age << "\t" << find -> Genre << endl;
                }
                else
                {
                    cout << "Игра не найдена" << endl;
                }
                break;
            case 4:
                Print (pbeg, pend);
                break;
            case 5:
                cout << "Пока..." << endl;
                break;
        }
    } while (UserChoise != 5);
 
 
    return 0;
}
Добавлено через 16 минут
Посмотрите кто нить плиз)

Добавлено через 28 минут
Тема закрыта! ошибки нашёл сам)
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
Текущее время: 08:29. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru