Форум программистов, компьютерный форум, киберфорум
Наши страницы
С++ для начинающих
Войти
Регистрация
Восстановить пароль
 
Рейтинг 4.60/5: Рейтинг темы: голосов - 5, средняя оценка - 4.60
sokol90
0 / 0 / 0
Регистрация: 12.12.2013
Сообщений: 16
1

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

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

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

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

Напечатать все слова четной длины
Дан текст. Напечатать все слова четной длины. Дублирование тем запрещено...

В текстовом файле найти длину самой длинной строки, и вывести на экран все строки данной длины
В данном текстовом файле найти длину самой длинной строки и вывести на экран...

задан файл неопределённой длины, прочитать все записи, номер которых кратен 5 и вывести их на экран
задан файл неопределённой длины, прочитать все записи, номер которых кратен 5 и...

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

3
MicM
824 / 483 / 324
Регистрация: 29.12.2009
Сообщений: 1,106
Завершенные тесты: 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;
}
1
sokol90
0 / 0 / 0
Регистрация: 12.12.2013
Сообщений: 16
22.12.2013, 15:19  [ТС] 3
MicM, а можно подробнее?
0
MicM
824 / 483 / 324
Регистрация: 29.12.2009
Сообщений: 1,106
Завершенные тесты: 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;
}
1
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
22.12.2013, 15:40

Вывести на экран все слова, количество букв в которых превышает введенное число
Необходимо вывести на экран все слова, количество букв в которых превышает...

Вывести все слова строки, в которых есть удвоение букв
Помогите написать программу которая выводит все слова из строки в которых есть...

Вывести все слова из строки длина которых меньше заданной
Составить программу посимвольной обработки,без всяких функций из strin.h(!!!),...


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

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

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