С Новым годом! Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.63/8: Рейтинг темы: голосов - 8, средняя оценка - 4.63
0 / 0 / 0
Регистрация: 22.05.2017
Сообщений: 4

Задача на преобразование слов

13.08.2020, 17:19. Показов 1819. Ответов 3

Студворк — интернет-сервис помощи студентам
Условие задачи следующее. На вход подается две строки, разделенные пробелом. Необходимо определить, возможно ли преобразовать первую строку во вторую с учетом правил:
- участвуют только буквы русского алфавита а-я;
- все буквы в нижнем регистре;
- за один шаг преобразуются все вхождения одной буквы в другую.
В качестве ответа в стандартный вывод программа должна выводить 1 (если преобразовать можно) или 0 (если преобразовать нельзя).

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

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
#include <iostream>
#include <string>
#include <stdio.h>
 
using namespace std;
 
int main()
{
    string s = "";
    string s1 = "";
    string s2 = "";
    int n = 0;
    cin >> s1 >> s2;
    cout << endl;
    cout << s1 << endl;
    cout << s2 << endl;
    if (s1.length() != s2.length())
    {
        cout << 0 << endl;
    }
    else
    {
        cout << 1 << endl;
    }
 
    return 0;
}
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
13.08.2020, 17:19
Ответы с готовыми решениями:

Преобразование слов
Каждая буква задана числом: а=1; б=2; в=3; г=4; д=5; е=6; ё=7; ж=8; з=9;

Преобразование слов в числа
Как сделать программу, когда вводишь слово &quot;два&quot;, программа должна преобразовать его в 2 и т.д.

Delphi. Преобразование слов
Доброго времени суток. Пишу программу на Delphi. Суть: Имеется текстовый файл, в нем слова в виде.. Слово Слово Слово И тд. ...

3
653 / 466 / 183
Регистрация: 23.04.2019
Сообщений: 1,987
13.08.2020, 18:49
Цитата Сообщение от ПЛАЧУЩИЙ АНГЕЛ Посмотреть сообщение
проверку возможности преобразования.
я вижу несколько вариантов
1. Перебирать 1 строку и находить соответствие во 2 строке
2. Подсчитать кол-во каждой буквы для каждой строки и сравнить

Добавлено через 7 минут
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
#include <iostream>
#include <string>
#include <algorithm>
 
int main()
{
    std::string s1 = "";
    std::string s2 = "";
    
    int n = 0;
    std::cout << std::endl;
    std::getline(std::cin, s1);
    std::getline(std::cin, s2);
    if (s1.length() != s2.length())
    {
        std::cout << 0 << std::endl;
    }
    else
    {
        for (size_t i = 0; i < s1.length(); i++)
        {
            char cur = s1[i];
            if (std::count_if(s1.begin(), s1.end(), [&cur](const char& ch) {return ch == cur; }) !=
                std::count_if(s2.begin(), s2.end(), [&cur](const char& ch) {return ch == cur; }))
            {
                std::cout << 0;
                exit(0);
            }
        }
        std::cout << 1;
    }
 
    return 0;
}
0
0 / 0 / 0
Регистрация: 22.05.2017
Сообщений: 4
16.08.2020, 08:25  [ТС]
Можете объяснить вот этот кусок?
(std::count_if(s1.begin(), s1.end(), [&cur](const char& ch) {return ch == cur; }) !=
std::count_if(s2.begin(), s2.end(), [&cur](const char& ch) {return ch == cur; }))
0
653 / 466 / 183
Регистрация: 23.04.2019
Сообщений: 1,987
16.08.2020, 17:52
Цитата Сообщение от ПЛАЧУЩИЙ АНГЕЛ Посмотреть сообщение
этот кусок
подсчёт совпадений
C++
1
std::count_if(s1.begin(), s1.end(), [&cur](const char& ch) {return ch == cur; })
например это подсчёт элементов между s1.begin() и s1.end(), которые получили значение true, при сравнении в лямбда-выражении с помощью std::count
там можно было использовать не count_if, а просто count (забыл)
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
16.08.2020, 17:52
Помогаю со студенческими работами здесь

Преобразование слов в строке
Дана строка содержащая от 2 до 10 слов, в каждом из которых от 2 до 10 латинских букв; между соседними словами не одного пробела, за...

Преобразование слов в цифры
вот задача: НАпишите программу преобразующую слова ноль-один-два. в цыфры 0-1-2. только я чёт немного запутался и почему то никак не могу...

Пошаговое преобразование слов
Калькулятор пошагово преобразует заданное 5-и буквенное слово в другое заданное слово, заменой одной буквы в предыдущем слове, так чтобы на...

Преобразование даты из слов в число
Собственно сабж, имеется переменная: $dater = '9 сентября 2016'; //может быть разные день и месяц и год Ее каким то образом нужно...

Преобразование строки в список слов
создать предикат, преобразующий строку в список слов


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

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Новые блоги и статьи
Модель микоризы: классовый агентный подход 3
anaschu 06.01.2026
aa0a7f55b50dd51c5ec569d2d10c54f6/ O1rJuneU_ls https:/ / vkvideo. ru/ video-115721503_456239114
Owen Logic: О недопустимости использования связки «аналоговый ПИД» + RegKZR
ФедосеевПавел 06.01.2026
Owen Logic: О недопустимости использования связки «аналоговый ПИД» + RegKZR ВВЕДЕНИЕ Введу сокращения: аналоговый ПИД — ПИД регулятор с управляющим выходом в виде числа в диапазоне от 0% до. . .
Модель микоризы: классовый агентный подход 2
anaschu 06.01.2026
репозиторий https:/ / github. com/ shumilovas/ fungi ветка по-частям. коммит Create переделка под биомассу. txt вход sc, но sm считается внутри мицелия. кстати, обьем тоже должен там считаться. . . .
Расчёт токов в цепи постоянного тока
igorrr37 05.01.2026
/ * Дана цепь постоянного тока с сопротивлениями и напряжениями. Надо найти токи в ветвях. Программа составляет систему уравнений по 1 и 2 законам Кирхгофа и решает её. Последовательность действий:. . .
Новый CodeBlocs. Версия 25.03
palva 04.01.2026
Оказывается, недавно вышла новая версия CodeBlocks за номером 25. 03. Когда-то давно я возился с только что вышедшей тогда версией 20. 03. С тех пор я давно снёс всё с компьютера и забыл. Теперь. . .
Модель микоризы: классовый агентный подход
anaschu 02.01.2026
Раньше это было два гриба и бактерия. Теперь три гриба, растение. И на уровне агентов добавится между грибами или бактериями взаимодействий. До того я пробовал подход через многомерные массивы,. . .
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
Programma_Boinc 28.12.2025
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост. Налог на собак: https:/ / **********/ gallery/ V06K53e Финансовый отчет в Excel: https:/ / **********/ gallery/ bKBkQFf Пост отсюда. . .
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США.
Programma_Boinc 26.12.2025
Нашел на реддите интересную статью под названием Anyone know where to get a free Desktop or Laptop? Ниже её машинный перевод. После долгих разбирательств я наконец-то вернула себе. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru