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

Написание ровнялки текста. - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Работа с файлом!!! http://www.cyberforum.ru/cpp-beginners/thread81485.html
Помогите пожалуйста написать программу на языке си: Задан текстовый файл С, состоящий из произвольной последовательности буквенных символов. Упорядочить символы в алфавитном порядке, при этом все...
C++ Структура с полями Помогите пожалуйста, никак не могу реализовать эту программу((( Запись о товаре на складе представляет собой структуру с полями: номер склада, код товара, наименование товара, дата поступления на... http://www.cyberforum.ru/cpp-beginners/thread81472.html
C++ статический массив ----> динамический массив
Есть программа, нужно статический массив заменить на динамический. Как будет выглядеть? #include <iostream> #include <windows.h> #include <fstream> #include <cstdlib> #include <cstring> ...
C++ скомпилировать структуру
у меня проблемы с Visual Studio!!!!плз ктонить скомпилируйте это и скажите работает ли...пробовал на онлайн компиляторах - вроде ошибок нет,но знаю как работает!!плз можете проверить!ну очень срочно...
C++ Строки http://www.cyberforum.ru/cpp-beginners/thread81459.html
В заданном тексте везде заменить слово 1 на слово 2 (длины слов в общем случае не совпадают). Помогите, даже не знаю с чего начать. Хотя бы наводку дайте, как это сделать Добавлено через 41...
C++ Подскажите программу с циклом while сдал преподу программу рабочюю нужно найти Сумму элементов, расположенных между первым и последним нулевыми элементами вот код #include <stdafx.h> #include <iostream> #include <conio.h> using... подробнее

Показать сообщение отдельно
easybudda
Модератор
Эксперт CЭксперт С++
9664 / 5614 / 952
Регистрация: 25.07.2009
Сообщений: 10,780
29.12.2009, 04:16
Каким-то я непростым путём пошёл... Получилось сложно и запутанно, но вроде работает. Проверял, правда, на одном только файле с буржуйским текстом - удачно...
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 OUT_WIDTH 60
#define FILE_NAME "simple.txt"
 
/* вывод массива слов по заданной ширине */
void printJustified(char **words, size_t count, size_t width){
    size_t all_len, spc_needed, spc_per_word, i, j;
    /* если слово всего одно - просто вывести */
    if ( count == 1 ){
        printf("%s\n", *words);
        return;
    }
    /* определить количество пробелов между словами */
    for ( all_len = 0, i = 0; i < count; ++i )
        all_len += strlen(words[i]);
    spc_needed = width - all_len;
    spc_per_word = (size_t)((double)spc_needed / (double)(count - 1) + 0.5);
    /* вывод */
    for ( i = 0; i < count; ++i ){
        printf("%s", words[i]);
        if ( i < count - 2 ){ /* пробелы после слова, если оно не последнее */
            for ( j = 0; j < spc_per_word && spc_needed > 0; ++j, --spc_needed )
                printf("%c", ' ');
        }
        else if ( i < count - 1 ){ /* перед последним словом все оставшиеся пробелы */
            while ( spc_needed-- )
                printf("%c", ' ');
        }
        else {
            printf("\n");
        }
    }
}
 
int main(void){
    FILE *f;
    int c, inword;
    char **words, buf[BUFSIZ], splitbuf[BUFSIZ], *p, *spl;
    size_t words_count, all_len, wrd_len, i;
    
    /* заклинание на открытие файла */
    if ( ( f = fopen(FILE_NAME, "r") ) == NULL ){
        perror("Can't open input file!\n");
        exit(1);
    }
    /* начальные значения */
    words = NULL;
    inword = 0;
    words_count = all_len = 0;
    p = buf;
    /* чтение файла по символу */
    /* while ( ( c = fgetc(f) ) != EOF ) */
    do {
        c = fgetc(f);
        switch ( c ){
            case ' ' :
            case '\t' :
            case '\n' :
            case EOF :
                if ( inword ){
                    *p = '\0';
                    inword = 0;
                    wrd_len = strlen(buf);
                    if ( all_len + wrd_len < OUT_WIDTH ){ /* добавить слово */
                        if ( ( words = (char**)realloc(words, sizeof(char*) * (words_count + 1)) ) == NULL ){
                            perror("Bad memory!\n");
                            exit(1);
                        }
                        if ( ( words[words_count] = strdup(buf) ) == NULL ){
                            perror("Bad memory!\n");
                            exit(1);
                        }
                        if ( all_len ) /* не первое слово */
                            all_len += wrd_len + 1;
                        else
                            all_len = wrd_len;
                        ++words_count;
                    }
                    else {
                        if ( words_count ){ /* если есть слова в массиве - вывести и обнулить */
                            printJustified(words, words_count, OUT_WIDTH);
                            for ( i = 0; i < words_count; ++i )
                                free(words[i]);
                            free(words);
                            words = NULL;
                            words_count = 0;
                            all_len = 0;
                        }
                        /* если слово длиннее окна вывода */
                        spl = buf;
                        while ( wrd_len > OUT_WIDTH ){
                            strncpy(splitbuf, spl, OUT_WIDTH);
                            splitbuf[OUT_WIDTH] = '\0';
                            printf("%s\n", splitbuf);
                            spl += OUT_WIDTH;
                            wrd_len = strlen(spl);
                        }
                        if ( wrd_len ){ /* хвост от слова, если остался, или всё слово в буфер */
                            if ( ( words = (char**)malloc(sizeof(char*)) ) == NULL ){
                                perror("Bad memory!\n");
                                exit(1);
                            }
                            if ( ( *words = strdup(spl) ) == NULL ){
                                perror("Bad memory!\n");
                                exit(1);
                            }
                            all_len = wrd_len;
                            words_count = 1;
                        }
                    }
                    /* указатель на начало буфера */
                    p = buf;                    
                }
                if ( c == '\n' ){ /* конец абзаца или пустая строка */
                    if ( words_count ){
                        printJustified(words, words_count, OUT_WIDTH);
                        for ( i = 0; i < words_count; ++i )
                            free(words[i]);
                        free(words);
                        words = NULL;
                        words_count = 0;
                        all_len = 0;
                    }
                    else{
                        printf("\n");
                    }
                }
                break;
            default :
                inword = 1;
                *p++ = c;
                break;
        }
    } while ( c != EOF );
    fclose(f);
    /* Если что-то осталось в буфере, вывести и очистить */
    if ( words ){
        printJustified(words, words_count, OUT_WIDTH);
        for ( i = 0; i < words_count; ++i ){
            if ( words[i] != NULL ){
                free(words[i]);
                words[i] = NULL;
            }
        }
        free(words);
        words = NULL;
    }
    
    exit(0);
}
Добавлено через 5 часов 45 минут
криво работало, поправил немного.
0
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru