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

С++ для начинающих

Войти
Регистрация
Восстановить пароль
 
Рейтинг: Рейтинг темы: голосов - 10, средняя оценка - 4.90
coldspirit
0 / 0 / 0
Регистрация: 30.10.2010
Сообщений: 39
#1

выравнивание по ширине - C++

16.01.2011, 18:05. Просмотров 1494. Ответов 1
Метки нет (Все метки)

составить программу, создающую другой текстовый файл, в котором строки из первого файла выровнены по ширине. Выравнивание производить за счёт добавления между слов необходимого количества пробелов.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
16.01.2011, 18:05     выравнивание по ширине
Посмотрите здесь:

Выравнивание текста пробелами по ширине. - C++
Очень нужно написать решение на C++. Кто-нибудь может помочь? Я пытался 2 дня - ничего не получается :( Задача Вашей программе...

Выравнивание по ширине как организовать? - C++
Дан вектор состоящий из строк нужно выровнять все строки в векторе по ширине подскажите как это сделать. vector<string> text;

Отредактировать текст по ширине - C++
#include "stdafx.h" #include <stdio.h> #include <stdlib.h> #include <conio.h> #include <locale.h> #include <windows.h> ...

RichEdit 3.0 и форматирование по ширине - C++
Я использую MFC. Пытаюсь сделать в RichEditView форматирование абзацев по ширине, но ничего не получается... PFA_JUSTIFY просто...

Выровнять строки текстового файла по ширине - C++
дан текстовый файл. выровнять все строки по ширине, выравнивание произвести по самой длинной строке файла. результат поместить в новый файл.

Прямоугольник из символов по заданной высоте и ширине - C++
Написать программу, которая запрашивает высоту и ширину, после чего выводит прямоугольник заданных размеров. Прямоугольник формируется из...

Отформатировать заданный массив строк по ширине поля - C++
Заданный массив строк произвольной длины. Отформатировать заданный массив строк по ширине поля.

Выравнивание - C++
Почему не происходит выравнивание текста по правому края? int main() { cout.setf(ios::right); cout << "Right"; return 0;...

Выравнивание - C++
Насколько я понимаю разрядность системы определяет размер машинного слова. Допустим, я использую Win7 x32, получается, что за 1 такт...

Не получается выравнивание - C++
Здравствуйте, форумчане! Я вот уже второй день не могу выполнить такую задачу (см. прикрепленный файл). Мой код: #include <stdio.h> ...

SSE2, выравнивание и new - C++
Потихонечку пишу свою длинную арифметку. И вот на этапе оптимизации мне нужно использовать команды SSE2. Но многие из них требуют...

Выравнивание структур - C++
typedef struct _WinBMPFileHeader { WORD FileType; DWORD FileSize; WORD ...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
lemegeton
2923 / 1352 / 135
Регистрация: 29.11.2010
Сообщений: 2,725
17.01.2011, 01:32     выравнивание по ширине #2
Считывает из файла, выводит на экран. Уж с выводом в файл-то справишься, надеюсь.
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
/*
  Выравнивание производить за счёт добавления между слов необходимого количества пробелов.
*/
#include <cstdio>
#include <cstdlib>
#include <ctime>
#include <cstddef>
#include <cstring>
 
void AlignString(char *string, size_t align_size) {
  char *symbol = string + strlen(string) - 1;
  size_t number_of_words = 0;
 
  // убираем конечные пробелы и символ переноса
  if (*symbol == '\n')
    --symbol;
  while ((symbol != string) && (*symbol == ' '))
    --symbol;
  *(symbol + 1) = '\0';
 
  if (strlen(string) == 0 || strlen(string) == align_size)
    return;
 
  // считаем слова
  symbol = string + 1;
  while (*symbol != '\0') {
    if ((symbol[-1] != ' ') && (symbol[0] == ' '))
      ++number_of_words;
    ++symbol;
  }
 
  if (number_of_words < 1)
    return;
 
  // расчетные величины
  size_t string_length = strlen(string);
  size_t spaces_to_add_definitely = (align_size - string_length) /
                                     number_of_words;
  size_t additional_spaces = (align_size - string_length) % number_of_words;
 
  // дополнение пробелами междусловные интервалы
  symbol = string + 1;
  size_t current_word_number = 0;
  while (*symbol != '\0') {
    if ((symbol[-1] != ' ') && (symbol[0] == ' ')) {
      size_t spaces_to_add = spaces_to_add_definitely +
                            ((current_word_number < additional_spaces)? 1:0);
      char *move_pointer  = string + align_size;
      while (move_pointer - spaces_to_add + 1 != symbol)
        *(move_pointer--) = *(move_pointer - spaces_to_add);
      for (int i = 0; i < spaces_to_add; ++i)
        *(symbol++) = ' ';
      ++current_word_number;
    }
    ++symbol;
  }
}
 
int main(int argc, char *argv[]) {
  size_t string_buffer_size = 2048;
 
  FILE* input_file = fopen("/usr/share/doc/libqt4-test/copyright", "r");
  size_t maximum_string_length = 0;
 
  if (input_file == NULL) {
    printf("Error opening file.\n");
    return 1;
  }
 
  char *string_buffer = new char[string_buffer_size];
  // первое чтение файла -- вычисление максимальной длины строки.
  while (!feof(input_file)) {
    if (fgets(string_buffer, string_buffer_size, input_file)) {
      size_t string_length = strlen(string_buffer);
      if (string_length > maximum_string_length)
        maximum_string_length = string_length;
    }
  }
 
  printf("Debug: maximum string length = %d.\n", maximum_string_length);
  fseek(input_file, 0, SEEK_SET);
 
  while (!feof(input_file)) {
    if (fgets(string_buffer, string_buffer_size, input_file)) {
      AlignString(string_buffer, maximum_string_length);
      printf("%s\n", string_buffer);
    }
  }
 
  delete [] string_buffer;
  fclose(input_file);
  return 0;
}
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru