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

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

Восстановить пароль Регистрация
Другие темы раздела
C++ Написать main() http://www.cyberforum.ru/cpp-beginners/thread588616.html
Всё сделал, осталось main() доработать!) Помогите? Само задание(Класс для принтеров): Необходимо разработать иерархию классов. Базовые классы иерархии должны быть абстрактными. В каждом классе иерархии нужно предусматривать: -наличие не менее трех конструкторов -виртуальный диструктор -перезагрузку операций. Обязательно перезагрузить операции: присваивания и декремента(в обеих формах),...
C++ Работа с динамическими структурами данных Ребята помогите нужно написать 3 программы: 1. Программирование динамических списков Написать программу, в которой реализовать создания динамического списка с последующим функционалом: а) добавление элементов в список; б) удаление элементов из списка; в) сортировка списка в алфавитном порядке. 2. Работа со стеком Создать программу, реализовав работу со структурой данных - стеком. В... http://www.cyberforum.ru/cpp-beginners/thread588612.html
С какой стороны функция C++
Перегрузил оператор:template<typename _My> _My& List<_My>::Iter::operator *() const { return *_Tptr; } Можно ли как-нибудь узнать с какой стороны от знака равенства стоит эта функция? Пробовал перегрузить таким образом: template<typename _My> _My& List<_My>::Iter::operator *() const { return *_Tptr; }
C++ Удалить первый элемент из списка
Всем хай! Есть задача, создать список и выполнить некие операции надо ним и так список: struct element { char a; element *next; };
C++ дано натуральное число N. Вычислить http://www.cyberforum.ru/cpp-beginners/thread588601.html
дано натуральное число N. Вычислить
C++ Функции пользователя.Корректировка На днях сдавать отчёты,а я уже который день бьюсь над этими задачами...Препод лично МНЕ ничего не хочет объяснять.Говорит,типа ты у нас вундеркинд,вот сам и думай..а я уже весь мозг сломал. Попробуйте-ка самолично выучить этот C++...Я ведь вам не робот всё-таки...=( Задача 1.Определить функцию пользователя (нестандартную функцию) B,которая задана выражением: B=sqrt(|x-fi|) Почему-то программа... подробнее

Показать сообщение отдельно
Kator
0 / 0 / 0
Регистрация: 27.05.2012
Сообщений: 14
27.05.2012, 23:08     Выравнивание текста по левому краю по ширине
Доброго времени суток. Мне очень требуется помощь в объяснении кода данной программы. Просто жизненно необходимо. Заранее благодарю)
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
#include "stdafx.h"
#include <stdio.h>
#include <stdlib.h>
#include <conio.h>
#include <iostream>
#include <string.h>
 
using namespace std;
 
void printAligned(char* str, int width);
 
int main(int, char**) {
    int width;
    cout << "Enter width to align: ";
    cin >> width;
    cout << "Enter text:" << endl;
 
    char** lines = (char**)malloc(sizeof(char*));
    int k = 0;
    char* newLine;
    do {
    lines = (char**) realloc(lines, sizeof(char*) * (k + 1));
    newLine = (char*) malloc(sizeof(char) * 255);
    gets(newLine);
    lines[k++] = newLine;
    } while (strlen(newLine) == 0 || newLine[strlen(newLine) - 1] != '.');
 
    cout << "Aligned text:" << endl;
    for (int i = 0; i < k; ++i) {
      
    printAligned(lines[i], width);
    free(lines[i]);
    }
    free(lines);
 
    getch();
    return 0;
}
 
 
void printAligned(char* str, int width) {
    if (strlen(str) == 0) {
    cout << endl;
    return;
    }
 
    int wordBegin = 0;
    char** words = (char**) malloc(sizeof(char*));
    int wordsSize = 0;
    while (wordBegin < strlen(str)) {
    if (str[wordBegin] == ' ') {
        wordBegin++;
        continue;
    }
 
    int wordLen = 1;
    while (wordBegin + wordLen < strlen(str)
        && str[wordBegin + wordLen] != ' ') {
        wordLen++;
    }
 
    words = (char**) realloc(words, sizeof(char*) * (wordsSize + 1));
    words[wordsSize] = strncpy((char*)malloc(sizeof(char)*(wordLen + 1)),
                     str + wordBegin, wordLen);
    words[wordsSize++][wordLen] = '\0';
    wordBegin += wordLen;
    }
 
    if (wordsSize == 0) {
    cout << endl;
    return;
    }
 
 
    for (int front = 0; front < wordsSize; ) {
    while (strlen(words[front]) > width) {
        char * toOut = strncpy((char*) malloc(sizeof(char) * (width + 1)),
                    words[front], width);
        char * rest = strcpy((char*) malloc(sizeof(char) * (strlen(words[front]) - width + 1)),
                    words[front] + width);
        toOut[width] = '\0';
        rest[strlen(words[front]) - width + 1] = '\0';
        cout << toOut << endl;
        free(words[front]);
        free(toOut);
        words[front] = rest;
    }
 
    int toPrint = 0;
    int toPrintW = 0;
    for (int i = front; i != wordsSize; ++i) {
        if (toPrintW + strlen(words[i]) + toPrint <= width) {
        toPrintW += strlen(words[i]);
        toPrint++;
        } else {
        break;
        }
    }
 
    if (toPrint > 1) {
        int spaces = (width - toPrintW) / (toPrint - 1); //пробелы между словами
        int spaces2 = (width - toPrintW) % (toPrint - 1);//кол-во слов с пробелами больше одного
        for (int j = 0; j < toPrint; ++j) {
        cout << words[front++];
 
        if (j != toPrint - 1) {
            for (int s = 0; s < spaces; ++s) cout << ' ';
            if (j < spaces2) cout << ' ';
        }
        }
    } else {
        cout << words[front++];
    }
    cout << endl;
    }
}
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
Текущее время: 20:45. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru