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

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

Восстановить пароль Регистрация
Другие темы раздела
C++ Работа с файлом!!! http://www.cyberforum.ru/cpp-beginners/thread81485.html
Помогите пожалуйста написать программу на языке си: Задан текстовый файл С, состоящий из произвольной последовательности буквенных символов. Упорядочить символы в алфавитном порядке, при этом все повторяющиеся символы должны быть удалены и переписать новый текст в файл D.
C++ Структура с полями Помогите пожалуйста, никак не могу реализовать эту программу((( Запись о товаре на складе представляет собой структуру с полями: номер склада, код товара, наименование товара, дата поступления на склад, срок хранения в днях, количество единиц товара, цена за единицу товара. Записи о товарах хранятся в файле. Реализовать функции: 1.1. Поиск по номеру склада 1.2. Поиск по коду товара 1.3.... http://www.cyberforum.ru/cpp-beginners/thread81472.html
C++ статический массив ----> динамический массив
Есть программа, нужно статический массив заменить на динамический. Как будет выглядеть? #include <iostream> #include <windows.h> #include <fstream> #include <cstdlib> #include <cstring> using namespace std; // Определение структуры struct sotrudnik
C++ скомпилировать структуру
у меня проблемы с Visual Studio!!!!плз ктонить скомпилируйте это и скажите работает ли...пробовал на онлайн компиляторах - вроде ошибок нет,но знаю как работает!!плз можете проверить!ну очень срочно надо.. #include "stdafx.h" #include <fstream> #include <iostream> #include <string> #include <stdlib.h> #include <windows.h>
C++ Строки http://www.cyberforum.ru/cpp-beginners/thread81459.html
В заданном тексте везде заменить слово 1 на слово 2 (длины слов в общем случае не совпадают). Помогите, даже не знаю с чего начать. Хотя бы наводку дайте, как это сделать Добавлено через 41 минуту как реализовать саму замену одного слова на другое?
C++ Подскажите программу с циклом while сдал преподу программу рабочюю нужно найти Сумму элементов, расположенных между первым и последним нулевыми элементами вот код #include <stdafx.h> #include <iostream> #include <conio.h> using namespace std; int main() { const int N = 10; int i = 0; int m ={10 , 0 , 22 , 30 , 14 , 0 , 9, 4 , 2 , 3 }; подробнее

Показать сообщение отдельно
easybudda
Модератор
Эксперт С++
 Аватар для easybudda
9373 / 5423 / 914
Регистрация: 25.07.2009
Сообщений: 10,423
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 минут
криво работало, поправил немного.
 
Текущее время: 18:46. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru