Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
6 / 6 / 0
Регистрация: 23.05.2013
Сообщений: 33

Создать однонаправленный линейный список и использовать его для решения задачи о заявках на авиабилеты

11.08.2016, 00:12. Показов 2975. Ответов 0
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Создать шаблон класса «однонаправленный линейный список». Использовать его при решении следующей задачи: Составить программу, которая содержит динамическую информацию о заявках на авиабилеты. Каждая заявка содержит:
• пункт назначения;
• номер рейса;
• фамилию и инициалы пассажира;
• желаемую дату вылета.
• Программа должна обеспечивать:
• хранение всех заявок в виде списка;
• добавление заявок в список;
• удаление заявок;
• вывод заявок по заданному номеру рейса и дате вылета;
• вывод всех заявок.

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
#include <iostream>
#include <clocale>
#include <iomanip>
#include <string>
using namespace std;
 
template<class Type>
struct ListNode{
    Type        data;   // Данные.
    ListNode*   next;   // Ссылка на след. элемент.
};
 
struct RequestData {
    string destination; // Пункт назначения.
    string reisNumber;  // Номер рейса.
    string fullName;    // ФИО.
    string date;        // Дата.
 
    RequestData(const string& destination = "", const string& reisNumber = "", const string& fullName = "", const string& date = "") :
        destination(destination),
        reisNumber(reisNumber),
        fullName(fullName),
        date(date) { }
 
    RequestData(const RequestData& data) :
        destination(data.destination),
        reisNumber(data.reisNumber),
        fullName(data.fullName),
        date(data.date) { }
};
 
class List {
private:
    ListNode<RequestData>*  _tail;  // Указатель на конец списка.
    ListNode<RequestData>*  _head;  // Указатель на начало списка.
public:
    List(): _tail(NULL), _head(NULL) { }
    ~List() { Del(); }
 
    int GetMenuKey(void);   // Функция получения пользовательского выбора.
    void CoutOne();         // Функция вывода элемента по номеру и дате вылета.
    void CoutAll();         // Функция вывода всего списка.
    void Add();             // Функция добавления элемента.
    void Del(void);         // Очистка списка.
};
 
 
int main(int argc, char** argv)
{
    setlocale(LC_ALL, "");
    List    list;   // Список заказов.
    short   key;    // Переменная для меню.
 
    /* Меню пользователя. */
    while((key = list.GetMenuKey())!=0) {
        switch(key) {
            case 1: list.Add(); break;
            case 2: list.CoutAll(); break;
            case 3: list.Del(); break;
            case 4: list.CoutOne(); break;
            case 5: break;
            default: cout << "Введите от 1 до 5" << endl; break;
        }
    }
    return 0;
}
/************** Реализациия **************/
int List::GetMenuKey(void)
{
    cout << setfill('=') << setw(50) << "\n";
    cout << "1 - Dobavit' Zayvky" << endl;
    cout << "2 - Vivesti vse zayvki na ekran" << endl;
    cout << "3 - Delete zayvky" << endl;
    cout << "4 - Vivod po nomery reisa" << endl;
    cout << "0 - Closed" << "\n" << setfill('=') << setw(50) << "\n" << endl;
    cout << setfill(' ');
    int key;
    cin >> key;
    cout << "\n";
    return key; // Функция возвращает значение, которое выбрал пользователь.
}
void List::CoutOne()
{
    /* Ввод пользователем номера рейса и даты вылета: */
    string num;
    cout << "Enter number reisa:" << "\n";
    cin >> num;
    string d;
    cout << "Enter date vilita (DD.MM.YY):" << "\n";
    cin >> d;
    cout << endl;
 
    int count = 0;
    // Цикл просмотра элементов.
    for (ListNode<RequestData>* t = _head; t->next != NULL; t = t->next)    {
        RequestData data = t->data;
        // Условие поиска элемента.
        if ((data.reisNumber == num) && (data.date == d)) {
            /* В случае совпадения выводится элемент: */
            cout << "Zayvka naidena:" << "\n";
            cout << "Punkt naznachenia:" << setw(8) << "Reis:" << setw(13)
                << "FIO:" << setw(15) << "Date vilita:" << endl;
            cout << setw(17) << data.destination << setw(8) << data.reisNumber << setw(13)
                << data.fullName << setw(15) << data.date << "\t" << "\n" << endl;
            ++count; // Счетчик количества найденных заявок.
        }
    }
 
    if (!count) // Если ничего не найдено.
        cout << "Nichego ne naidena!" << "\n" << endl;
}
 
void List::CoutAll()
{
    if (!_head)
        return;
 
    for (ListNode<RequestData>* node = _head; node != NULL; node = node->next) {
        RequestData data = node->data;
        cout << setw(17) << data.destination << setw(8) << data.reisNumber << setw(13) << data.fullName << setw(15) << data.date << "\t" << endl;
    }
}
 
void List::Del(void)
{
    for (ListNode<RequestData>* node = _head; node != NULL;) {
        ListNode<RequestData>* next = node->next;
        delete node;
        node = next;
    }
    _head = NULL;
    _tail = NULL;
}
 
void List::Add()
{
    RequestData node;
    /*заполнение нового элемента:*/
    cout << "Введите пункт назначения:"<<endl;
    cin >> node.destination;
    cout << "Введите номер рейса:"<<endl;
    cin >> node.reisNumber;
    cout << "Введите ФИО пассажира:"<<endl;
    cin >> node.fullName;
    cout << "Введите дату вылета (в формате DD.MM.YY):"<<endl;
    cin >> node.date;
    cout << "\n";
    ListNode<RequestData>* newNode = new ListNode<RequestData>;
    newNode->data = node;
    newNode->next = NULL;
    if (_tail)
        _tail->next = newNode;
    if (!_head)
        _head = newNode;
    _tail = newNode;}
[удалено]
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
11.08.2016, 00:12
Ответы с готовыми решениями:

Однонаправленный линейный список - динамическую информацию о заявках на авиабилеты
Контрольная работа БНТУ МИДО 2 курс 15 вариант - возможно, кому-то пригодится... Постановка задачи Создать шаблон класса...

Создать линейный однонаправленный список из целых чисел
Создать линейный однонаправленный список из целых чисел. Определить среднее арифметическое значений элементов списка, кратных 4. ...

Упорядочить список по возрастанию (для решения задачи использовать STL)
Во входном файле в первой строке три слова и число (13 12 65) в последующих тоже самое. Проверьте код, пожалуйста, выводит непонятные...

0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
11.08.2016, 00:12
Помогаю со студенческими работами здесь

Линейный, однонаправленный, связанный список для структур
Всем привет! Помогите пожалуйста переделать эту программу, так чтобы в нем использовались не массивы структурных переменных, а линейный,...

В консольном режиме Delphi создать модуль, реализующий ниже перечисленные задачи и использовать его в программе для их решения.
Помогите плиз... В текстовом файле представлена информация об аудиофайлах. Описание одного аудиофайла включает: автор, название, тип...

Создать линейный однонаправленный список из целых чисел
Создать линейный однонаправленный список из целых чисел. Удалить из списка первый четный элемент, стоящий на нечетной позиции. С#

Создать линейный однонаправленный список из вещественных чисел
1. Создать линейный однонаправленный список из вещественных чисел. Вставить в список первый отрицательный элемент перед каждым числом,...

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


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

Или воспользуйтесь поиском по форуму:
1
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Обработчик клика мыши в браузере ПК и касания экрана в браузере на мобильном устройстве
8Observer8 02.02.2026
Содержание блога Для начала пошагово создадим рабочий пример для подготовки к экспериментам в браузере ПК и в браузере мобильного устройства. Потом напишем обработчик клика мыши и обработчик. . .
Философия технологии
iceja 01.02.2026
На мой взгляд у человека в технических проектах остается роль генерального директора. Все остальное нейронки делают уже лучше человека. Они не могут нести предпринимательские риски, не могут. . .
SDL3 для Web (WebAssembly): Вывод текста со шрифтом TTF с помощью SDL3_ttf
8Observer8 01.02.2026
Содержание блога В этой пошаговой инструкции создадим с нуля веб-приложение, которое выводит текст в окне браузера. Запустим на Android на локальном сервере. Загрузим Release на бесплатный. . .
SDL3 для Web (WebAssembly): Сборка C/C++ проекта из консоли
8Observer8 30.01.2026
Содержание блога Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
SDL3 для Web (WebAssembly): Установка Emscripten SDK (emsdk) и CMake для сборки C и C++ приложений в Wasm
8Observer8 30.01.2026
Содержание блога Для того чтобы скачать Emscripten SDK (emsdk) необходимо сначало скачать и уставить Git: Install for Windows. Следуйте стандартной процедуре установки Git через установщик. . . .
SDL3 для Android: Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 29.01.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами. Версия v3 была полностью переписана на Си, в. . .
Инструменты COM: Сохранение данный из VARIANT в файл и загрузка из файла в VARIANT
bedvit 28.01.2026
Сохранение базовых типов COM и массивов (одномерных или двухмерных) любой вложенности (деревья) в файл, с возможностью выбора алгоритмов сжатия и шифрования. Часть библиотеки BedvitCOM Использованы. . .
SDL3 для Android: Загрузка PNG с альфа-каналом с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 28.01.2026
Содержание блога SDL3 имеет собственные средства для загрузки и отображения PNG-файлов с альфа-каналом и базовой работы с ними. В этой инструкции используется функция SDL_LoadPNG(), которая. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru