С Новым годом! Форум программистов, компьютерный форум, киберфорум
Наши страницы

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

Войти
Регистрация
Восстановить пароль
 
kristi1
10 / 10 / 1
Регистрация: 07.03.2010
Сообщений: 465
#1

Строки, обработка - C++

25.03.2012, 22:28. Просмотров 317. Ответов 0
Метки нет (Все метки)

Добрый вечер, я написала программу, но она не совсем верно работает, посмотрите пожалуйста, я ошибку найти не могу, тыкните мордочкой, очень вас прошу, спасибо=)
Задание само:
произвольный заданный текст вывести в виде абзаца с заданной длиной строки. При этом обозначить отступ от левого края в первой строка абзаца на заданное число позиций; размещение каждого слова целиком в одной и той же строке, (ликвидировать переносы, которые обозначены в тексте знаком "-" в конце строки)
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
#include "fstream"
#include "iostream"
#include "vector"
 
template<class Type>
struct myvec
{
    myvec()
    {
        val = nullptr;
        sz = 0;
    }
 
    Type& operator[](int n)
    {
        return val[n];
    }
 
    void push_back(Type t)
    {
        Type* tmp = new Type[sz + 1];
        memcpy(tmp, val, sizeof(Type) * sz);
        delete[] val;
        val = tmp;
        
        val[sz++] = t;
    }
    void push_front(Type t)
    {
        Type* tmp = new Type[sz + 1];
        memcpy(tmp + 1, val, sizeof(Type) * sz);
        
        delete[] val;
        val = tmp;
        val[0] = t;
        sz++;
    }
    void erase(size_t n)
    {
        n++;
        Type* tmp = new Type[sz - 1];
        memcpy(tmp, val, sizeof(Type) * (n - 1));
 
        delete[] val[n - 1];
        memcpy(tmp + (n - 1), val + (n), sizeof(Type) * (sz - (n - 1)));
        
        delete[] val;
        val = tmp;
        sz--;
    }
    size_t size()
    {
        return sz;
    }
protected:
    Type* val;
    size_t sz;
};
struct param
{
    int tablen;
    int strln;
};
 
void process(myvec<char*> text, param p, myvec<char*> &ntext)
{
    for (size_t i = 0; i < text.size() - 1; i++)
    {
        if (strrchr(text[i], '-'))
        {
            size_t sz = strlen(text[i]) + strlen(text[i + 1]) - 1;
            char* n = new char[sz];
            memcpy(n, text[i], strlen(text[i]) - 1);
            memcpy(n + strlen(text[i]) - 1, text[i + 1], strlen(text[i + 1]));
            text.erase(i + 1);
            text[i] = n;
            text[i][sz] = 0;
            i--;
        }
    }
 
    size_t itr = 0;
 
    for (size_t i = 0; i < p.tablen; i++)
        text.push_front(" ");
 
    while(itr < text.size())
    {
        int jtr = p.strln;
        
        ntext.push_back(new char[128]);
        ntext[ntext.size() - 1][0] = 0;
 
        while(jtr >= strlen(text[itr]) || ( jtr == p.strln && p.strln < strlen(text[itr]) ) )
        {
            strcat(ntext[ntext.size() - 1], text[itr]);
            
            if (!isspace(*text[itr]))
                strcat(ntext[ntext.size() - 1], " ");
            
            jtr -= strlen(text[itr++]);
 
            if (jtr <= 0)
                break;
 
            if (itr == text.size())
                return;
        }
 
    }
}
 
int main()
{
    std::ifstream fin("in.txt", std::ios::in);
    std::ofstream fout("out.txt", std::ios::out);
 
    myvec<char*> strings;
    strings.push_back(new char[512]);
 
    int i = 0;
    while(fin >> strings[i])
    {
        i++;
        strings.push_back(new char[512]);
    }
 
    param p;
    std::cout << "Please, enter tab and string length : ";
    std::cin >> p.tablen >> p.strln;
    myvec<char*> ns;
    process(strings, p, ns);
 
    for (size_t i = 0; i < ns.size(); i++)
        fout << ns[i] << "\n";
 
    return 0;
}
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
25.03.2012, 22:28
Здравствуйте! Я подобрал для вас темы с ответами на вопрос Строки, обработка (C++):

Обработка строки - C++
здравствуйте. такая задача: написать функцию, входным параметром которой является указатель на строку. функция должна вернуть количество...

Строки обработка - C++
Задание. ВВести строку, отставить в строке только симметричные фрагменты длинной мин 5 символов. Например asdsa. Остальные заменить на...

обработка строки - C++
Обработка строки при помощи указателей Задание : для ввода всех строк использовать один и тот же символьный массив tmp . ...

Обработка строки - C++
Здравствуйте. У меня есть строка: нолщаувсдлч ощзхзждцвыбьчля start Как удалить все до слова start?

обработка строки в с++ - C++
дана строка(вводимая пользователем с клавиатуры). найти и вывести те слова из строки которые начинаются и заканчиваются на одну и ту же...

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

0
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
25.03.2012, 22:28
Привет! Вот еще темы с ответами:

Обработка строки - C++
Доброе время суток. Имеется такая задача : Дана строка, содержащая слова, разделенные одним или несколькими разделительными символами...

Обработка символьной строки - C++
Посчитал кол-во символов в строке. Но вот как добавить цифру? #include &quot;stdafx.h&quot; #include &lt;stdio.h&gt; #include &lt;string.h&gt; ...

Обработка каждой строки - C++
Вот такое задание &quot; Ввести матрицу , вывести ее. В каждой строке матрицы опре-делить, сколько в ней положительных, сколько отрицательных и...

Обработка текстовой строки - C++
Собственно задание определить, имеются ли в строке изображения двоичных чисел. написал данную прогу. #include &quot;stdafx.h&quot; #include...


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

Или воспользуйтесь поиском по форуму:
1
Ответ Создать тему
Опции темы

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