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

Текстовый файл - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Почему возникает ошибка? http://www.cyberforum.ru/cpp-beginners/thread127141.html
template <class T> class HashTable { .... }; class FileHashTable: public HashTable <Policy> { public: FileHashTable() // здесь возникает ошибка: error C2512: 'HashTable<struct Policy>' :...
C++ Определить, сколько раз встречается в файле введенное пользователем слово Дан текстовый файл. Напишите программу, которая определяет, сколько раз встречается в файле введенное пользователем слово. файл: C:\file.txt http://www.cyberforum.ru/cpp-beginners/thread127136.html
C++ Как правильно записать наследника от такого класса?
template <class T> class Me{ ...} От класса Me?
C++ Количество элементов парит
В одномерном массиве из n вещественных элементов как определить количество 0 в этом массиве?
C++ как мне обойти все подкаталоги данного каталога.? http://www.cyberforum.ru/cpp-beginners/thread127119.html
помогите плз разобраться с директориями. вот как мне обойти все подкаталоги данного каталога.?
C++ Из Pascal в С++ Дана действительная матрица размером n*m. Упорядочить (переставить) за спадением значений первых элементов столбцов program zada4a333; uses crt; const nmax=20; var a:array of real; ... подробнее

Показать сообщение отдельно
dev001
36 / 36 / 3
Регистрация: 13.05.2010
Сообщений: 70
20.05.2010, 12:56
Не знаю на сколько проще получилось, но вроде то

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
#include <stdlib.h>
#include <stdio.h>
#include <sys/stat.h>
#include <string.h>
#include <ctype.h>
 
#define ROUND(l) (((l) + (8 - 1)) & ~(8 - 1))
 
char *wordwrap(const char *text, int linelen);
static char *read_line(char *buf, char **ret) {
    char *p = buf;
    if(*p == '\n') buf = p++;
 
    for(;; p++) {
        if(*p == '\n') 
            break;
    }
 
    *p = '\0';
    *ret = buf;
    buf = ++p;
    return buf;
}
 
int main(int argc, char **argv) {
    struct stat st;
    FILE *in;
    char *in_buf, *wrap_buf, *f_col, *s_col, *left, *right;
    int inlen, col_len;
 
    in = fopen("input.txt", "r");
    if(stat("input.txt", &st) < 0 || !in) { /* получим информацию о файл в данном случае интересен будет его размер */
        printf("can't open input file input.txt");
        goto exit_error;
    }
    in_buf = malloc(st.st_size + 1);
    inlen = fread(in_buf, 1, st.st_size, in);
    fclose(in);
 
    wrap_buf = wordwrap(in_buf, 40); /* упакуем текст в столбец ширина которого 40 сим. */
    
    free(in_buf); /* освободим то что прочитали из файла */
    col_len = ROUND(inlen / 2); /* округляем чтобы уж точно на 2 разбилось :) */
    f_col = wrap_buf; /* левая колонка */
    s_col = wrap_buf + col_len; /* правая колонка */
    
    for(; s_col <wrap_buf + inlen; ) {
        f_col = read_line(f_col, &left); /* читаем по строчно левую колонку */
        s_col = read_line(s_col, &right); /* читаем по строчно правую колонку */
        printf("%-55s%-55s\n", left, right); /* печатаем по строчно правую и левую */
    }
    free(wrap_buf); /* освобождаем память после использование wordwrap */
    return 0;
exit_error:
    return 255;
}
 
/* Функция упаковывания текст по заданой длине */
char *wordwrap(const char *text, int linelen) {
    char *newtext = NULL;
    int textlen = 0, i, p, q;
    
    textlen = strlen(text);
    newtext = strdup(text);
    p = 0;
    for (i = 0; i < textlen; i++) {
        
        if (newtext[i] == '\n' || newtext[i] == '\r') {
            q = p = i;
        } else if (newtext[i] == ' ') {
            if (i - q > linelen) {
                newtext[i] = '\n';
                q = i + 1;
            }
            p = i;
        } else if (i - q > linelen && q != p) {
            newtext[p] = '\n';
            q = p + 1;
        }
    }   
    newtext[textlen] = '\0';
    return newtext;
}
0
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru