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

работа с файлами - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Динамические массивы( Visual Studio 2005 С++) http://www.cyberforum.ru/cpp-beginners/thread71323.html
Прошу извинить меня за то что повторяюсь. Эта тема тут поднималась неоднократно. но я так и не смог найти ни чего толкового для себя. Собственно что мне нужно: 1. Как объявить динамический массивы 2. Как изменять длину динамического массива 3. Как обращаться к элементу массива За ранее благодарен.
C++ Лаб. раб Помогите пожалуйста разобраться с заданием http://dencom.nsknet.ru/_mod_files/ce_images/2009-12-07_115738.png http://www.cyberforum.ru/cpp-beginners/thread71319.html
динамические массивы C++
помогите разобраться с динамическими массивами . Надо составить программу которая: Изменяла порядок следования элементов массива на противоположный. Находила наибольший элемент побочной диагонали матрицы. Задачу нужно решить через функции с использованием динамических массивов.
Подключение glut.h C++
всем здрасте еще раз! я бы хотел спросить , как подключить библиотеку glut.h ? я его скачал. а вот к компилятору подключить никак...
C++ Поиск в файле и вывод на экран http://www.cyberforum.ru/cpp-beginners/thread71269.html
Имеется txt файл, произвольно заполненный: 01101210 :2 //пустая строка 12434 :8 //пустая строка 0110 :9 //пустая строка
C++ странный ввод чисел В чем проблема, не пойму. #include <iostream.h> #include <conio.h> #include <stdio.h> void main() {char a,b,c,v; clrscr(); cout <<" vvedite znachenia\n"; scanf ("%d %d %d",&a,&b,&c); подробнее

Показать сообщение отдельно
easybudda
Модератор
Эксперт С++
 Аватар для easybudda
9384 / 5434 / 916
Регистрация: 25.07.2009
Сообщений: 10,428
07.12.2009, 18:48     работа с файлами
Особо не проверял, но вроде работает
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
171
172
173
174
175
176
177
178
179
180
181
182
183
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
 
/*
    В справочной автовокзала хранится расписание движения автобусов. Для каждого рейса указаны:
    -номер рейса;
    -тип автобуса;
    -пункт назначения;
    -время отправления;
    -время прибытия на конечный пункт.
 
    Проблема: просмотр,заполнение, добавление, вывод информации о рейсах, которыми можно воспользоваться для прибытия 
    в пункт назначения раньше заданного времени.
*/
 
#define STR_LEN 100
 
typedef struct {
    int _h;
    int _m;
} Time_t;
 
/* заполнение структуры Time_t. возвращает 0, если удачно */
int fillTime(Time_t *tm){
    if ( !tm )
        return 1;
    do {
        printf("Часы (0 - 23): ");
        if ( !scanf("%d", &(tm->_h)) )
            return 1;
    } while ( ( tm->_h < 0 || tm->_h > 23 ) && printf("Неверное значение!\n") );
    do {
        printf("Минуты (0 - 59): ");
        if ( !scanf("%d", &(tm->_m)) )
            return 1;
    } while ( ( tm->_m < 0 || tm->_m > 59 ) && printf("Неверное значение!\n") );
    
    return 0;
}
    
 
typedef struct {
    int _num;
    char _type[STR_LEN];
    char _dest[STR_LEN];
    Time_t _start;
    Time_t _finish;
} Route_t;
 
/* Заполнялка структуры Route_t. Возвращает 0, если удачно */
int fillRoute(Route_t *r){
    char *p;
    if (!r )
        return 1;
    printf("Номер рейса: ");
    if ( !scanf("%d", &(r->_num)) )
        return 1;
    getchar();
    printf("Тип автобуса: ");
    if ( !fgets(r->_type, STR_LEN, stdin) )
        return 1;
    if ( p = strrchr(r->_type, '\n') )
        *p = '\0';
    printf("Пункт назначения: ");
    if ( !fgets(r->_dest, STR_LEN, stdin) )
        return 1;
    if ( p = strrchr(r->_dest, '\n') )
        *p = '\0';
    printf("Время отправления:\n");
    fillTime(&(r->_start));
    printf("Время прибытия:\n");
    fillTime(&(r->_finish));
    
    return 0;
}
 
/* вывод заголовка */
void printTitle(void){
    printf("#  Тип            Пункт назначения    Отпр.   Приб.\n-------------------------------------------------------\n");
}
 
/* вывод в одну строку */
void printLine(size_t ln, Route_t *r){
    printf("%-3d%-15s%-20s%02d:%02d   %02d:%02d\n", ln, r->_type, r->_dest, r->_start._h, r->_start._m, r->_finish._h, r->_finish._m);
}
 
/* сравнивалка по времени прибытия для qsort */
int cmpByFinish(const void *a, const void *b){
    Time_t ta, tb;
    ta = (*(Route_t*)a)._finish;
    tb = (*(Route_t*)b)._finish;
    if ( ta._h == tb._h )
        return ( ta._m - tb._m );
    return ( ta._h - tb._h );
}
 
/* вывод меню */
int menu(void){
    int c;
    
    do {
        printf("1 - просмотреть все маршруты; 2 - добавить новый; 3 - найти по пункту назначения и времени прибытия; 4 - выход\n");
        scanf("%d", &c);
    } while ( (c < 1 || c > 4) && printf("Неверный выбор") );
    getchar();
    return c;
}
    
 
int main(void){
    Route_t *routes = NULL, tmp;
    size_t count = 0, i, found;
    int action, stop = 0;
    char *p;
    
    while ( !stop ){
        printf("Маршрутов в базе: %d\n", count);
        action = menu();
        switch ( action ){
            case 1:
                if ( count == 0 )
                    printf("\nНет маршрутов\n");
                else{
                    printTitle();
                    for ( i = 0; i < count; i++ )
                        printLine(i + 1, routes + i);
                    printf("-------------------------------------------------------\n");
                }
                break;
            case 2:
                if ( count == 0 ){
                    if ( (routes = (Route_t*)malloc(sizeof(Route_t))) == NULL ){
                        fprintf(stderr, "Memory error!\n");
                        exit(1);
                    }
                }
                else{
                    if ( (routes = (Route_t*)realloc((void*)routes, sizeof(Route_t) * (count + 1))) == NULL ){
                        fprintf(stderr, "Memory error!\n");
                        exit(1);
                    }
                }
                if ( fillRoute(routes + count) != 0 ){
                    fprintf(stderr, "Can't fill route!\n");
                    exit(1);
                }
                count++;
                break;
            case 3:
                if ( !count ){
                    printf("\nНет маршрутов\n");
                    break;
                }
                printf("Пункт назначения: ");
                fgets(tmp._dest, STR_LEN, stdin);
                if ( p = strrchr(tmp._dest, '\n') )
                    *p = '\0';
                printf("Время прибытия:\n");
                fillTime(&tmp._finish);
                
                qsort((void*)routes, count, sizeof(Route_t), cmpByFinish);
                printTitle();
                for ( i = 0; i < count; i++ )
                    if ( !strcmp(routes[i]._dest, tmp._dest) && 
                        (routes[i]._finish._h < tmp._finish._h || (routes[i]._finish._h == tmp._finish._h && routes[i]._finish._m < tmp._finish._m))
                    )
                        printLine(i + 1, routes + i);
                printf("-------------------------------------------------------\n");
                break;
            case 4:
                stop = 1;
                break;
        }
    }
    
    if ( routes != NULL ){
        free(routes);
        routes = NULL;
    }
    
    exit(0);
}
PS Называйте темы как-то более содержательно - еле нашёл её...
 
Текущее время: 11:07. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru