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

Помогите доработать программу. - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Виды ошибок. http://www.cyberforum.ru/cpp-beginners/thread388072.html
error C2109: subscript requires array or pointer type Что это озночает и как исправить?
C++ N и M числитель и знаменатель дроби, составить программу, позволяющая сократить эту дробь. помогите пожалуйста http://www.cyberforum.ru/cpp-beginners/thread388044.html
Сформировать новый массив из больших 8 C++
Дан массив C(15). Сформировать новый массив из больших 8 чисел исходного
Вывести на экран через запятую все делители натурал. числа N, кратные 2 C++
Вывести на экран через запятую все делители натурал. числа N, кратные 2
C++ какой тип выбрать http://www.cyberforum.ru/cpp-beginners/thread388037.html
пишу программку по структурам, возник вопрос какой тип лучше присвоить дате... чар подойдет?:gscratch:
C++ задача на рекурентную формулу вычислить с точностью \varepsilon =10^{-5} , сумму ряда : f(x)=\sum_{n=0}^{\propto }\frac{x^{2n}}{(2n)!} (сумма от нуля до бесконечности, в числителе x в степени 2n, в знаменателе факториал от 2n) подробнее

Показать сообщение отдельно
Gadjett
 Аватар для Gadjett
0 / 0 / 0
Регистрация: 20.11.2011
Сообщений: 20
20.11.2011, 20:55     Помогите доработать программу.
Вот мое задание.
Составить программу, которая содержит динамическую информацию о наличии автобусов в
автобусном парке.
Сведения о каждом автобусе содержат:
* номер автобуса;
* фамилию и инициалы водителя;
* номер маршрута.
Программа должна обеспечивать:
* начальное формирование данных о, всех автобусах в парке в виде списка;
* при выезде каждого автобуса из парка вводится номер автобуса, и программа удаляет данные
об этом автобусе из списка автобусов, находящихся в парке, и записывает эти данные в
список автобусов, находящихся на маршруте;
* при въезде каждого автобуса в парк вводится номер автобуса, и программа удаляет данные об
этом автобусе из списка автобусов, находящихся на маршруте, и записывает эти данные в
список автобусов, находящихся в парке;
* по запросу выдаются сведения об автобусах, находящихся в парке, или об автобусах,
находящихся на маршруте.

А вот до чего я дошел, и застыл
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
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
 
#define L_NAME 64
#define IN 0
#define OUT 1
/* ---------------------------- STRUCT NODE ------------------------------ */
struct node {
    int number, /* (0 <-> 13) */
        route, /* (0 <-> 3]) */
        is_in_park; /* (IN, OUT) */
    char driver[ L_NAME ],
        conductor[ L_NAME ];
    struct node*
        next;
};
 
 
/* ------------------------------ LIST ADD ------------------------------- */
 
struct node* list_add(
struct node **p,
    const int number,
    const int route,
    const char* driver ){
 
        struct node *n = (struct node *)malloc( sizeof(struct node) );
        if (n == NULL) {
            puts( "Can't add new item. Something with memory." );
            return NULL;
        }
 
        n->next = *p; /* The previous elm (*p) becomes the "next" element. */
        *p = n; /* Add new empty element to the head of the list. */
 
        n->number = number;
        n->route = route;
        n->is_in_park = 0;
        strcpy( n->driver, driver );
 
        return *p;
}
 
 
/* ---------------------------- LIST REMOVE ------------------------------ */
/* Remove head. */
 
void list_remove(struct node **p) {
    if (*p != NULL) {
        struct node *n = *p;
        *p = (*p)->next;
        free(n);
    }
}
 
 
/* ------------------------- LIST SEARCH NUMBER -------------------------- */
 
struct node** list_search_number(struct node **n, const int number) {
    while (*n != NULL) {
        if ( (*n)->number == number )
            return n;
        n = &(*n)->next;
    }
    return NULL;
}
 
 
/* ----------------------------- LIST PRINT ------------------------------ */
 
void list_print(struct node *n, const int inout) {
    puts("");
    if (n == NULL)
        printf("List is empty.\n");
    while (n != NULL) {
        if ( inout == IN && n->is_in_park == OUT );
        else if ( inout == OUT && n->is_in_park == IN );
        else
            printf( "> n: %i, \tr: %i, \tdr: %s, \ti/o:%i\n",
            n->number,
            n->route,
            n->driver,
            n->is_in_park );
        n = n->next;
    }
}
 
 
/* ------------------------- LIST CHANGE INOUT --------------------------- */
 
void list_inout(struct node *n, const int inout) {
    int number;
    struct node *p = n;
 
    printf("enter number: "); scanf("%i", &number);
    if ( list_search_number(&n, number) == NULL )
        puts("No such bus.");
    return;
 
    p = *(list_search_number(&n, number));
    p->is_in_park = inout;
}
 
 
/* -------------------------------- MENU --------------------------------- */
 
void help() {
    puts( "____________________" );
    puts( "1: print list" );
    puts( "2: bus getting out" );
    puts( "3: bus getting in" );
    puts( "4: list_inside" );
    puts( "5: list_outside" );
    puts( "6: quit" );
    puts( "____________________" );
}
 
 
/* -------------------------------- MAIN --------------------------------- */
 
int main(void) {
    char buffer[ L_NAME ];
    struct node *n = NULL;
    int number;
    int error = 999; /* forsomefirecase. (c)promt*/
 
    list_add( &n, 1, 1, "V. Pupkin" );
    list_add( &n, 2, 3, "G. Zopin" );
    list_add( &n, 3, 3, "Mad Max" );
    list_add( &n, 4, 2, "<BB>" );
 
    puts( "Print 'h' for help." );
 
    /* Main Loop. */
    /* while (1) { */
    while (error--) { /* forsomefirecase. (c)promt*/
        printf( "$ " );
        scanf( "%s", &buffer );
 
        if ( !strcmp(buffer, "1" ) ) list_print( n, 2 );
        else if ( !strcmp(buffer, "2" ) ) list_print( n, OUT );
        else if ( !strcmp(buffer, "3" ) ) list_print( n, IN );
        else if ( !strcmp(buffer, "4" ) ) list_inout( n, IN );
        else if ( !strcmp(buffer, "5" ) ) list_inout( n, OUT );
        else if ( !strcmp(buffer, "6" ) ) exit (0);
        else if ( !strcmp(buffer, "h" ) ) help();
        else
            puts( "No such command. See 'h'." );
    }
 
    return 0;
}
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
Текущее время: 09:06. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru