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

Упаковка слов в строке - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ база лото http://www.cyberforum.ru/cpp-beginners/thread82767.html
товарищи как сделать прогу чтоб забивать туда результаты например лото и чтоб выдавала рандомом самый оптимальный вариант?
C++ Одна ошибка #include<iostream> using namespace std; int max_elem(int **mas, int n); int main(void); { int i, j, temp; mas=new int*; or(i=0; i<n; i++); mas=new int; cout<<"Введите элементы матрицы: "<< endl; http://www.cyberforum.ru/cpp-beginners/thread82762.html
упростить программу нахождения ряда C++
имеется задача: неиспользуя стандартные функции,за исключением abs вычислить сумму n первых членов, n вводится с клавиатуры. я решил ее так, но это не правильно, и при введении числа больше 5 на экране никакого результата вообще не выводиться если продолжить ряд таким способом. сам ряд описан на картинке ниже #include <stdio.h> #include <conio.h> #include <math.h> #include <stdlib.h> void...
printf - знак процента на экран C++
#include <iostream> int main() { int n, m; scanf("%d%d", &n, &m); int* a = (int*) calloc(n,sizeof(int)); for (int i = 0; i < m; ++i) { int d;
C++ Взаимодействие клиента с автоматом продажи кофе http://www.cyberforum.ru/cpp-beginners/thread82726.html
Тема курсовика, через неделю нужно сдавать (учусь на вечернем) а я вот только начал вникать в азы программирования на Си. Написать нужно методом ООП. Подскажите какие можно написать классы и т.д. С чего хоть начать. Спасибо.
C++ Портировать из С в Delphi или паскаль Если не трудно переделайте код из си в паскаль или делфи #include "stdio.h" #include "iostream.h" #include "math.h" const double PI = 3.1415926536; // проверка матрицы на диагональность bool isSimmetrial( double **coefficients, int numberOfEquation ) { bool result = true; подробнее

Показать сообщение отдельно
den_spb
0 / 0 / 0
Регистрация: 19.11.2009
Сообщений: 12
05.01.2010, 16:48     Упаковка слов в строке
Ввести массив строк текста с заданным количеством строк и массив символов разделителей. Количество символов разделителей заранее неизвестно. Ввод элементов этого массива заканчивается повторением любого из символов, введённых ранее. Из введённого текста сформировать другой массив строк, в котором задано максимальное количество символов в строке. Слова в этих строках должны быть упакованы максимально плотно с удалением лишних символов разделителей между ними и будут отсутствовать переносы слов с одной строки на другую. Одновременно из этих строк удалить слова с минимальным в этой строке количеством символов. Вывести исходный и сформированный текст.

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;
}
Мне правда надо все это переделать под С.
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
Текущее время: 09:48. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru