Форум программистов, компьютерный форум, киберфорум
Наши страницы
С++ для начинающих
Войти
Регистрация
Восстановить пароль
 
Тина_Ливингстон
0 / 0 / 0
Регистрация: 01.11.2011
Сообщений: 59
1

Работа со строками

29.11.2011, 21:44. Просмотров 411. Ответов 0
Метки нет (Все метки)

Строкане более чем из 256 символов, буквосочетания не более чем из 2 букв.
Найти слово максимальной минимальной длины в строке, все слова разделены пробелами,
нужно удалить между маx и мин слова, начинащееся на заданное буквосочетаниею После удаления между мах и мин словами сцепить слова попарно. После удалить слова, заканчивающиеся на заданное буквосочетание и вывести полученную строку.
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
#include <iostream>
#include <cstring>
void main ()
{
    using namespace std;
    int n,pmin,dmin,pmax,dmax,k=1,k1=0,t=0;
    char str[256];
    cout<<"enter"<<endl;
    cin.getline(str,257);
    n=strlen(str);
    if (str[0]==' ')
        while (str[k]==' ')
        {
            k++;
            k1=k;
        }
    while (str[k]!=' ')
            k++;
    dmin=k-k1;
    dmax=k-k1;
    pmin=k1;
    pmax=k1;
    for (int i=k;i<n;i++)
    {
        if (str[i]!=' ')
            t++;
        else
        {
            if (t>dmax)
            {
                dmax=t;
                pmax=i-t;
            }
            if (t<dmin && t!=0)
            {
                dmin=t;
                pmin=i-t;
            }
            t=0;
        }
    }
    int s=k,d;
    for (int i=s;i<n;i++)
    {
        if (str[i]!=' ' && str[i-1]==' ')
        {
            k=i;
            k1=i;
            while (str[k]!=' ')
                k++;
            d=k-k1;
            if (d>dmax)
            {
                dmax=d;
                pmax=k1;
            }
            if (d<=dmin)
            {
                dmin=d;
                pmin=k1;
            }
        }
    }
    cout<<dmax<<" "<<pmax<<endl<<dmin<<" "<<pmin<<endl;
    if (pmin>pmax)
    {
        int bot;
        bot=pmin;
        pmin=pmax;
        pmax=bot;
    }
    char BB[3];
    cout<<"enter 2"<<endl;
    cin.getline(BB,3);
    for (int i=pmin+1;i<pmax-1;i++)
    {
        if (str[i]==BB[0] && str[i-1]==' ' && str[i+1]==BB[1])
        {
            k=i;
            k1=i;
            while (str[k]!=' ')
                k++;
            d=k-k1;
            
            for (int f=k;f<n;f++)
                str[f-d]=str[f];
            n-=d;
            pmax=pmax-d;
        }
    }
for (int i=0;i<n;i++)
    cout<<str[i];
cout<<endl;
}
программа неправльно работает, не знаю, где ошибка=(


И нужно переделать программу так, что бы буквосочетание могло состоять из одной ли двух букв!
0
QA
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
29.11.2011, 21:44
Ответы с готовыми решениями:

Работа со строками. Функции работы со строками
Дана строка символов. В заданном тексте определить позицию первой точки ‘ . ‘.

Работа со строками
Даны два слова. Для каждой буквы первого слова определить, входит ли она во второе слово....

Работа со строками
Написать программу, которая считывает текст и определяет, сколько в нем слов, состоящих не более...

Работа со строками
Даны строки S1 и S2. Удалить из строки S1 последнюю подстроку, совпадающую с S2. Если совпадающих...

Работа со строками
Имеется задачка (олимпиадная, но олимпиада уже прошла): Новый кодовый замок для владельцев...

0
Answers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
29.11.2011, 21:44

Работа со строками
Всем привет. Есть такой код void makeStr() { std::string testStr = &quot;Take...

Работа со строками С++
Задача вот с таким условием: В строке все вхождения подстроки str1 заменить подстрокой str2. Str2...

Работа со строками C++
Решил посвятить этой проблеме отдельную тему. В попытке написать ответ к этой задаче на С++...


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

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

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