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

Строки. Вывести на экран все слова четной длины, у которых... - C++

Восстановить пароль Регистрация
 
sokol90
0 / 0 / 0
Регистрация: 12.12.2013
Сообщений: 16
22.12.2013, 11:03     Строки. Вывести на экран все слова четной длины, у которых... #1
Дана последовательность символов, состоящая из слов четной длины. Вывести на экран все слова четной длины, у которых все буквы из первой половины слова встречаются во второй половине слова, или сообщение «Нет», если требуемых слов нет
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
22.12.2013, 11:03     Строки. Вывести на экран все слова четной длины, у которых...
Посмотрите здесь:

Строки: вывести на экран слова четной длинны C++
Вывести на экран слова четной длинны в одной строке,нечетной в другой C++
C++ Вывести все слова строки, в которых есть удвоение букв
C++ Строки: Вывести на экран только те слова, которые отличаются от последнего и в которых нет повторяющихся букв.
Что здесь неправильно? (Вывести все слова строки в которых первая буква входит в него ещё раз) C++
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
MicM
 Аватар для MicM
820 / 487 / 90
Регистрация: 29.12.2009
Сообщений: 1,097
Завершенные тесты: 1
22.12.2013, 11:46     Строки. Вывести на экран все слова четной длины, у которых... #2
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
#include <iostream>
#include <string>
#include <cctype>
 
int main()
{
    std::string str = "kiju mama dfgfdh jmkmkj papa qwerty hji whow";
    std::string tmp,left,right;
    int i = 0;
    bool f = true,word = false;
    while (i<str.length())
    {
        if (isalpha(str[i]))
        {
            tmp.erase (0,tmp.size());
            while (i<str.length() && isalpha(str[i]))
            {
                tmp.append (1,str[i]);
                ++i;
            }
            if (tmp.size()%2==0)
            {
                f = true;
                left.erase (0,left.size());
                right.erase (0,right.size());
                for (int j=0; j<tmp.size(); j++)
                    if (j<tmp.size()/2)
                        left.append (1,tmp[j]);
                    else right.append (1,tmp[j]);
                for (int j=0; j<left.size(); j++)
                    if (right.find(left[j])==-1)
                    {
                        f = false;
                        break;
                    }
            }
            if (f)
            {
                word = true;
                std::cout <<tmp <<std::endl;
            }
        }
        else ++i;
    }
    if (!word)
        std::cout <<"No\n";
    return 0;
}
sokol90
0 / 0 / 0
Регистрация: 12.12.2013
Сообщений: 16
22.12.2013, 15:19  [ТС]     Строки. Вывести на экран все слова четной длины, у которых... #3
MicM, а можно подробнее?
MicM
 Аватар для MicM
820 / 487 / 90
Регистрация: 29.12.2009
Сообщений: 1,097
Завершенные тесты: 1
22.12.2013, 15:40     Строки. Вывести на экран все слова четной длины, у которых... #4
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
#include <iostream>
#include <string>
#include <cctype>
 
int main()
{
    std::string str = "kiju mama dfgfdh jmkmkj papa qwerty hji whow";
    std::string tmp,left,right;
    int i = 0;
    bool f = true,word = false;
    while (i<str.length())//в цикле идем по всей строке
    {
        if (isalpha(str[i]))//если очередной символ - буква,то
        {
            tmp.erase (0,tmp.size());//очищаем переменную для хранения слова
            while (i<str.length() && isalpha(str[i]))
            {
                tmp.append (1,str[i]);//формируем слово
                ++i;//увеличиваем счетчик
            }
            if (tmp.size()%2==0)//если кол-во символов в слове четно,то
            {
                f = true;//предположим, что левая и правая части состоят из одних и тех же букв
                left.erase (0,left.size());//очищаем переменные для хранения левой и правой частей слова
                right.erase (0,right.size());
                for (int j=0; j<tmp.size(); j++)//проходимся по полученному слову в tmp
                    if (j<tmp.size()/2)//если находимся в левой части слова,то
                        left.append (1,tmp[j]);//записываем в соответстувующую переменную
                    else right.append (1,tmp[j]);//иначе аналогично
                for (int j=0; j<left.size(); j++)//проходимся по левой части слова
                    if (right.find(left[j])==-1)//если какой-то буквы нет в правой части,то
                    {
                        f = false;
                        break;//выходим из цикла
                    }
            }
            if (f)//если левая и правая части состоят из одних и тех же букв
            {
                word = true;//фиксируем то,что такие слова есть
                std::cout <<tmp <<std::endl;//выводим слово
            }
        }
        else ++i;//иначе, если символ не буква, то идем дальше
    }
    if (!word)//если таких слов нет,то
        std::cout <<"No\n";//выводим "No"
    return 0;
}
Yandex
Объявления
22.12.2013, 15:40     Строки. Вывести на экран все слова четной длины, у которых...
Ответ Создать тему
Опции темы

Текущее время: 10:48. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru