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

Выравниваем строки по правому и левому краям - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Что не так в программе? (цикл While) http://www.cyberforum.ru/cpp-beginners/thread374488.html
Условие: Написать программу, которая находит сумму всех целых нечетных чисел в диапазоне, указанном пользователем. #include <iostream> using namespace std; int main() { int summa=0,a,b,n=a;...
C++ Что такое композиция? Добрый день. Тут читаю книгу и в ней приводится длинющий и непонятный пример композиции. Попросил бы Вас привести простенький пример композиции, то есть классы как элементы других классов. Желательно... http://www.cyberforum.ru/cpp-beginners/thread374480.html
Вопросы по C++ C++
Хочу учиться писать программы на C++, и у меня несколько вопросов 1) Этот язык такой же сложный, как Ассемблер? Например, Паскаль мне легко даётся, а вот Ассемблер никак не могу понять. 2) Чем...
Задача, которая считает наибольший общий делитель C++
Условие такое: Найти наибольший общий делитель чисел a и b. Для решения воспользоваться алгоритмом Евклида: уменьшать каждый раз большее из чисел на величину меньшего, до тех пор пока оба значения...
C++ Создать функцию, которая формирует строку, включив в нее все совпадающие символы двух строк http://www.cyberforum.ru/cpp-beginners/thread374455.html
создать функцию которая формирует строку, включив в нее все совпадающие символы двух строк
C++ Вывести название месяца и количество дней в нем создать программу, которая печатает название месяца и количество дней в месяце. год вводится с клавиатуры подробнее

Показать сообщение отдельно
*Jazz*
0 / 0 / 0
Регистрация: 29.10.2011
Сообщений: 3

Выравниваем строки по правому и левому краям - C++

29.10.2011, 15:27. Просмотров 1818. Ответов 3
Метки (Все метки)

Задача:

Создать программу, которая бы запрашивала у пользователя строки до тех пор, пока он не введет пустую строку, после чего программа должна вывести список введенных строк в два столбца, первый из которых выровнен по левому краю, а второй - по правому краю. То есть результат программы может выглядеть примерно следующим образом:

Aarhus
Aaron
Ababa
aback
abaft
abandon
abandoned
abandoning
abandonment
abandons
abase
abased
abasement
abasements


Решение:

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
#include <vector>
#include <string>
#include <stdio>
using namespace std;
 
int main()
{
  vector<string> coll;
  vector<string>::const_iterator pos;
 
  try
  {
    char input[80];
    string str;
    while(true)
    {
      printf("Введите строку ");
      fgets(input, 80, stdin);
      // Если введена пустая строка - выходим из цикла
      if(strlen(input) <= 1) break;
      // Удаляем завершающий перевод строки
      input[strlen(input) - 1] = '\0';
      // Присваиваем строке str значение input
      str = input;
      coll.push_back(str);
    }
    // Если количество элементов не четное,
    // добавляем дополнительный пустой элемент
    if(coll.size() % 2) coll.push_back("");
 
    // Определяем количество элементов в каждом из столбцов
    int half_count = coll.size() / 2;
 
    // Определяем длину максимальной строки
    // в первом столбце
    int max_lenght_first = 0;
    for(int i = 0; i < half_count; i++)
    {
      if(coll[i].size() > max_lenght_first)
        max_lenght_first = coll[i].size();
    }
 
    // Определяем длину максимальной строки
    // во втором столбце
    int max_lenght_second = 0;
    for(int i = half_count; i < coll.size(); i++)
    {
      if(coll[i].size() > max_lenght_second)
        max_lenght_second = coll[i].size();
    }
 
    // Строки форматирования для первого и второго столбцов
    char format_first[80], format_second[80];
    sprintf(format_first, "%%-%ds", max_lenght_first + 2);
    sprintf(format_second, "%%%ds\n", max_lenght_second);
 
    for(int i = 0; i < coll.size(); i++)
    {
      if(i % 2) printf(format_second, coll[i]);
      else printf(format_first, coll[i]);
    }
  }
  catch(bad_alloc)
  {
    printf("Не удалось выделить память под коллекцию\n");
  }
 
  return 0;
}
Для выводы строк в два столбца необходимо разбить коллекцию на две части для первого и второго столбца. В двух частях следует найти строки с максимальным количеством символов и подготовить две форматирующие строки: с выравниванием по левому краю для первого столбца и выравниванием по правому краю для правого столбца.
P.S. выше написана одна из возможных реализаций решения задачи.
Спасибо за внимание.
Написано - "*Jazz*" Специально для cyberforum.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru