Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
 
Рейтинг 4.62/13: Рейтинг темы: голосов - 13, средняя оценка - 4.62
0 / 0 / 0
Регистрация: 18.01.2019
Сообщений: 41
1

Найти во введенном тексте все слова-палиндромы

06.02.2019, 16:38. Показов 2657. Ответов 3
Метки нет (Все метки)

Нужна прога, я на первом курсе колледжа. Нужно все просто и понятно.
Разработать программу, которая вводит текст и находит в нем все слова-палиндромы. Палиндромом называется слово, если оно одинаково читается слева направо и справа налево. Примеры палиндромов: «казак», «55», «q», «xyzzy», «кабак».
__________________
Помощь в написании контрольных, курсовых и дипломных работ здесь
0
Лучшие ответы (1)
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
06.02.2019, 16:38
Ответы с готовыми решениями:

Найти в заданном тексте, состоящем из n строк, все слова палиндромы и числа палиндромы
Сроки жутко горят :( поэтому надеюсь на вашу помощь: Задача: Найти в заданном тексте, состоящем...

Найти в тексте, состоящем из 1 строки, все слова и числа-палиндромы
Найдите в заданном тексте, состоящем из 1 строки, все слова и числа-палиндромы. Необходимо ввести...

Найти в тексте слова-палиндромы
C клавиатуры задается произвольный текст, содержащий не более 10 строк, в каждой строке не более 80...

Найти в тексте симметричные слова (палиндромы)
Дан текст. Найти в нем все симметричные слова. Различие строчных и прописных букв во внимание не...

3
Модератор
Эксперт С++
11481 / 9399 / 5649
Регистрация: 18.12.2011
Сообщений: 25,108
06.02.2019, 16:53 2
См. ссылки внизу страницы
0
568 / 407 / 132
Регистрация: 22.11.2017
Сообщений: 1,079
06.02.2019, 19:07 3
Forka1, привет!
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
#include <iostream>
#include <limits>
#include <vector>
#include <xstring>
#include <string>
 
using namespace std;
 
template<class T>
vector<T> split(const T &s, const T &separators);
 
wstring wstring_towupper(const wstring &s);
 
int main()
{
    system("color 0A");
    wcout.imbue(locale("rus_rus.866"));
    wcin.imbue(locale("rus_rus.866"));
 
    wcout << L"Введите текст" << endl;
    wstring str;
    getline(wcin, str);
    auto words = split(str, wstring(L" .,!?()[]:'\"*^%&$"));
    for (const auto &word : words)
    {
        auto mirror(word);
        reverse(mirror.begin(), mirror.end());
        wcout << (
            wstring_towupper(word) == wstring_towupper(mirror) ? word + L" " : L""
            );
    }
    wcout << endl;
 
    system("pause");
    return 0;
}
 
template<class T>
vector<T> split(const T &s, const T &separators)
{
    vector<T> words;
    T word;
    for (const auto &c : s)
    {
        bool is_separator = (separators.find(c) != T::npos);
        if (is_separator && !word.empty())
        {
            words.push_back(word);
            word.clear();
        }
        else if (!is_separator)
        {
            word.push_back(c);
        }
    }
    if (!word.empty())
    {
        words.push_back(word);
    }
    return words;
}
 
wstring wstring_towupper(const wstring &s)
{
    wstring output;
    setlocale(LC_ALL, "Russian");
    for (const auto &wch : s)
    {
        output.push_back(towupper(wch));
    }
    setlocale(LC_ALL, "C");
    return output;
}
Миниатюры
Найти во введенном тексте все слова-палиндромы  
0
568 / 407 / 132
Регистрация: 22.11.2017
Сообщений: 1,079
06.02.2019, 19:14 4
Лучший ответ Сообщение было отмечено Forka1 как решение

Решение

Улучшил код.
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
#include <iostream>
#include <limits>
#include <vector>
#include <xstring>
#include <string>
#include <algorithm>
 
using namespace std;
 
template<class T>
vector<T> split(const T &s, const T &separators);
 
wstring wstring_towlower(const wstring &s);
 
int main()
{
    system("color 0A");
    wcout.imbue(locale("rus_rus.866"));
    wcin.imbue(locale("rus_rus.866"));
 
    wcout << L"Введите текст" << endl;
    wstring str;
    getline(wcin, str);
    auto words = split(str, wstring(L" .,!?()[]:'\"*^%&$"));
    for (auto &word : words)
    {
        word = wstring_towlower(word);
        auto mirror(word);
        reverse(mirror.begin(), mirror.end());
        wcout << (
            word == mirror ? word + L" " : L""
            );
    }
    wcout << endl;
 
    system("pause");
    return 0;
}
 
template<class T>
vector<T> split(const T &s, const T &separators)
{
    vector<T> words;
    T word;
    for (const auto &c : s)
    {
        bool is_separator = (separators.find(c) != T::npos);
        if (is_separator && !word.empty())
        {
            words.push_back(word);
            word.clear();
        }
        else if (!is_separator)
        {
            word.push_back(c);
        }
    }
    if (!word.empty())
    {
        words.push_back(word);
    }
    return words;
}
 
wstring wstring_towlower(const wstring &s)
{
    wstring output;
    setlocale(LC_ALL, "Russian");
    transform(s.begin(), s.end(), back_inserter(output), ::towlower);
    setlocale(LC_ALL, "C");
    return output;
}
2
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
06.02.2019, 19:14

Во введенном тексте найти повторяющиеся слова
Подскажите пожалуйста как решить задачки: Во введенном тексте найти повторяющиеся слова

В данном тексте найти все слова-палиндромы и вывести их на экран
Проблема в том, что при вводе двух и более знаков препинания подряд (включая пробелы) программа...

Дан текст.Найти все палиндромы(слова-перевёртыши)в етом тексте
Доброго времени суток ув.форумчане!Нужна ваша помощь в решении задачи по программированию.Язык...

В тексте слова разделены пробелами, найти и вывести слова-палиндромы
Доброго времени суток! Хочу попросить вас о помощи в написании програмы с таким условием: Задан...


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

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

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