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

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

22.12.2013, 11:03. Показов 2319. Ответов 3
Метки нет (Все метки)

Дана последовательность символов, состоящая из слов четной длины. Вывести на экран все слова четной длины, у которых все буквы из первой половины слова встречаются во второй половине слова, или сообщение «Нет», если требуемых слов нет
__________________
Помощь в написании контрольных, курсовых и дипломных работ, диссертаций здесь
0
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
22.12.2013, 11:03
Ответы с готовыми решениями:

Вывести все слова четной длины, у которых все буквы из первой половины слова встречаются во второй
Задача: Дана последовательность символов, состоящая из слов четной длины. Вывести на экран все...

В функции вывести на экран все слова строки длина которых больше длины первого слова
Вывести символьную строку. В функции вывести на экран все слова строки длина которых больше длины...

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

Распечатать все слова четной длины, в которых нет удвоенной буквы Н
уважаемые эксперты помогите пожалуйста с заданием 27.1. Дана матрица размером 6Х6 элементов,...

3
840 / 498 / 325
Регистрация: 29.12.2009
Сообщений: 1,106
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;
}
1
0 / 0 / 0
Регистрация: 12.12.2013
Сообщений: 16
22.12.2013, 15:19  [ТС] 3
MicM, а можно подробнее?
0
840 / 498 / 325
Регистрация: 29.12.2009
Сообщений: 1,106
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;
}
1
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
22.12.2013, 15:40
Помогаю со студенческими работами здесь

Вывести на экран все слова строки данной длины
помогите!! на паскале

Найти и вывести все слова четной длины, начинающиеся и заканчивающиеся на гласную букву
Помогите с прогой плиз.... 1. Вводится строка символов. Разделители – &lt;,&gt;.? /';&quot;)*( - заданы...

Строки. Вывести на экран все слова, в которых все буквы разные
Дан текст из слов, разделенных пробелами. Вывести на экран все слова, в которых все буквы разные....

Строки: вывести на экран слова четной длинны
Вводим строку, требуется вывести на экран слова четной длинны в одной строке,нечетной в...


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

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

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