0 / 0 / 0
Регистрация: 19.11.2009
Сообщений: 12
1

Упаковка слов в строке

05.01.2010, 16:48. Показов 1741. Ответов 0
Метки нет (Все метки)

Author24 — интернет-сервис помощи студентам
Ввести массив строк текста с заданным количеством строк и массив символов разделителей. Количество символов разделителей заранее неизвестно. Ввод элементов этого массива заканчивается повторением любого из символов, введённых ранее. Из введённого текста сформировать другой массив строк, в котором задано максимальное количество символов в строке. Слова в этих строках должны быть упакованы максимально плотно с удалением лишних символов разделителей между ними и будут отсутствовать переносы слов с одной строки на другую. Одновременно из этих строк удалить слова с минимальным в этой строке количеством символов. Вывести исходный и сформированный текст.

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
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
#include <iostream.h>
#include <iomanip.h>
#include <math.h>
#include <conio.h>
#include <stdlib.h>
#include <string.h>
#include <ctype.h>
 
//using namespace std;
 
const int MAX_LEN=80; //Максимальная длина одной строки
const int N=2; //кол во строк в тексте
const int K=5; // кол во символов в последнем условии
 
int main()
{
        
    char text[N][MAX_LEN]; // исходный массив текста
    char text2[MAX_LEN][MAX_LEN]; // преобразованный массив с текстом
    char stroka[N*MAX_LEN]; 
    char newstroka[N*MAX_LEN];
    char newstroka2[N*MAX_LEN];
    char razdel[80][1]; // массив с разделителями
    int kolr; // кол во разделителей
    int t=0;
    int i=0;
    int h=1;
 
    cout << "Enter text: ";
 
    // Вводим текст
 
    for (i=0;i<N;i++)
    {
 
    
    cin.getline(text[i],MAX_LEN);
    }
 
    // Вводим разделители
 
    do
    {
    cout << "Enter razdelitili:";
    cin>>razdel[i];
    
    if (i==0)
    {
        i++;
    }
    else
    {
        for (int j=0;j<i;j++)
            {
                if(razdel[j][0]==razdel[i][0])
                {
                    h=0;
                }
        }
        i++;    
    }
    }
    while(h==1);
 
 
 
    razdel[i-1][0]=' '; // добавляем разделитель пробел
    kolr=i-1;
 
    // Удаляем самое короткое слово из строки
 
    int min;
    int x,y,k,tx,ty;
    
 
    for (i=0;i<N;i++)
    {
        min=strlen(text[i]);
        tx=0;
        ty=0;
        x=0;
        y=0;
        k=0;
        for(int j=0;j<strlen(text[i]);j++)
        {
            if((isalnum(text[i][j])!=0)&&(k==0))
            {
                x=j;
                k++;
            }
            else
            {
            if((isalnum(text[i][j])!=0)&&(k!=0))
            {
                y=j;
                k++;
            }
            else
            {
            if((isalnum(text[i][j])==0)&&(k!=0))
            {
                y=j;
                if (min>=k)
                {
                    tx=x-1;
                    ty=y;
                    min=k;
                }
                k=0;
            }
            }
            }
            
        }
        int n=0;
        for (int h=0;h<strlen(text[i]);h++)
        {
            if((h<=tx)||(h>=ty))
                {
                    text[i][n]=text[i][h];
                    n++;
                }
        }
 
    }
    
    // Преобразуем весь текст в одну строку, чтобы удобнее было удалять лишнии символы
 
    k=0;
    for (i=0;i<N;i++)
    {
        for (int j=0;j<strlen(text[i]);j++)
        {
            stroka[k]=text[i][j];
            k++;
        }
    }
    stroka[k]='\0';
 
    // Удаляем повторяющиеся разделители и пробелы
    k=0;
    int j;
    char temp[1];
    temp[0]='`';
    for(i=0;i<strlen(stroka);i++)
    {
        if(temp[0]!=stroka[i])
        {
        for (j=0;j<kolr;j++)
        {
            if (stroka[i]==razdel[j][0])
            {
                temp[0]=stroka[i];
                t=0;
                newstroka[k]=razdel[j][0];
                k++;
                
            }
        }
        if(t==1)
        {
            temp[0]=stroka[i];
            newstroka[k]=stroka[i];
            k++;
        }
        t=1;
        }
    }
 
    newstroka[k++]='\0';
 
    
    k=0;
 
    // Удаляем символы переноса текста
 
    for (i=0;i<strlen(newstroka);i++)
    {
        if(newstroka[i]!='-')
        {
        newstroka2[k]=newstroka[i];
        k++;
        }
    }
    newstroka2[k++]='\0';
 
    
 
    // Преобразуем текст по N символов в строку
 
    k=0;
    j=0;
    for(i=0;i<strlen(newstroka2);i++)
    {
        text2[j][k]=newstroka2[i];
        k++;
        if (k==5)
        {
            text2[j][k]='\0';
            j++;
            k=0;
        }
    }
 
    // Выводим полученный текст
 
    for (i=0;i<j;i++)
    {
        for(int k=0;k<strlen(text2[i]);k++)
        {
            cout<<text2[i][k];
        }
        cout<<endl<<endl;
    }
 
    cin.get();
    cin.get();
    return 0;
}
Мне правда надо все это переделать под С.
0
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
05.01.2010, 16:48
Ответы с готовыми решениями:

Поиск слов по маске в строке, их удаление, сортировка оставшихся слов
Доброго времени суток. Помогите, пожалуйста, реализовать задачу. нужно из текстового файла считать...

Подсчитать сколько слов HELLO среди введенных слов в строке
Пользователь вводит строки, пока не введёт слово &quot;exit&quot;. Программа подсчитывает количество слов...

Количество слов в заданной строке (для каждого из слов)
дано символьная строка. Слово-последовательность символов между пробелами, не содержащие пробелы...

Cтрока: Определить количество средних слов в строке и какое из слов начинается на большую по коду букву
Определить количество средних слов в строе и какое из слов начинается на большую по коду букву. ...

0
05.01.2010, 16:48
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
05.01.2010, 16:48
Помогаю со студенческими работами здесь

В заданной строке определить количество слов (в строке может содержаться несколько пробелов подряд).
В заданной строке определить количество слов (в строке может содержаться несколько пробелов подряд).

Вычыслить количество слов в строке, длинна которых равна 3 символам и вывести их на экран, если же таких слов нет, то выдать об этом сообщение.
Вычыслить количество слов в строке, длинна которых равна 3 символам и вывести их на экран, если же...

Массив символов (Подсчитать количество слов в строке, при условии, что в качестве разделителя слов используется один или несколько пробелов)
Написать программу, в которой с клавиатуры вводится строка символов. Подсчитать количество слов в...

Количество слов в строке
Надо задать пользователю ввести строку с клавиатуры, вывести каждое слово по отдельности и около...


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

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

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2024, CyberForum.ru