Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.87/55: Рейтинг темы: голосов - 55, средняя оценка - 4.87
2 / 2 / 0
Регистрация: 29.09.2015
Сообщений: 10

Строки. Поиск одинаковых слов в предложениях. Вывод вместо одинаковых слов "*"

01.01.2017, 23:25. Показов 11060. Ответов 5
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Ввести два предложения, если в них есть одинаковые слова то во втором предложении заменить эти слова на "*", причем количество "*" должно равняться количеству букв в слове, которое мы заменяем.

Написала пока такое. Работает только если у нас одно слово одинаковое. Пыталась создать динамический массив слов, но чего-то не получается. Подскажите, пожалуйста, как или может это все можно совсем проще реализовать?

Еще мне нельзя использовать в этой задаче ничего помимо стандартных функций из string.h.
Видела уже на этом форуме (вот тут -- "https://www.cyberforum.ru/cpp-beginners/thread1594789.html") ответ на подобную задачу, но там используются вектора и многое другое - что не понимаю, поэтому разобраться не удалось.

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
74
75
76
77
78
79
80
#include "stdafx.h"
#include "iostream"
#include "conio.h"
#include "string.h"
using namespace std;
const int n = 100;
 
int main( )
{
    char *p;
 
    char s[80] , *res[n];
    char s1[80], *res1[n];
    char s2[] = { " " };
    cout << "Enter string " << endl;
    cin.getline(s, 80);
    
    cout << "Enter second string " << endl;
    cin.getline(s1, 80);
    
        strcat(s, s2);
    strcat(s, s1);
 
    cout << s;
    int k = 0, k1=0;
    char *slovo;
    
 
    res[k] = strtok(s, " ");
    while (res[k])
    {
        k++;
        res[k] = strtok(NULL, " ");
    }
    
    
 
    int count = 0;
    for (int i = 0; i < k; i++)
    {
        bool b = true;
        for (int j = i + 1; j < k; j++)
        {
            if (!strcmp(res[i], res[j]))
                b = false;
        }
        if (!b)
        {
            count++;
            slovo = res[i];//слово
        }
    }
    if (count)
    cout << endl << "Kol-vo odinak slov v stroke: " << count << " slovo " << slovo << endl;
    else
        cout << "NOT FOUND";
 
    p = strtok(s1, " ");//смотрим сколько лексем во 2 предложении
    while (p !=NULL)
    {
        
        int len = strlen(p);
 
        for (int i = 0; i < len; i++)
        {
            
            if (p[i] == *slovo)
            {
                strset(p, '*');
            }
        }
        cout << p << " ";
        
        p = strtok(NULL, " ");
    }
 
    _getch();
    return 0;
 
}
0
Лучшие ответы (1)
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
01.01.2017, 23:25
Ответы с готовыми решениями:

RichTexBox поиск одинаковых слов в предложениях
Собственно вот код. string split1 = { &quot;.&quot;, Environment.NewLine };//и так далее string split2 = { &quot;...

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

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

5
 Аватар для Fixer_84
1505 / 969 / 812
Регистрация: 30.04.2016
Сообщений: 3,337
01.01.2017, 23:40
OksanaD, я мог бы решить задачу с использованием векторов или строковых массивов. Но вам, насколько я понимаю, можно использовать только символьный массив char[]? А если использовать тип данных string - вам такое решение подойдет? Вообще, мне, кажется, лучше хранить слова этих предложений в векторах. Так будет проще заменить. Отпишитесь, пожалуйста.

Добавлено через 2 минуты
OksanaD, P.S. Чем разделяются слова в предложениях?
0
2 / 2 / 0
Регистрация: 29.09.2015
Сообщений: 10
01.01.2017, 23:46  [ТС]
Fixer_84, Да, использовать можно только символьный массив char[]. К сожалению, даже тип данных string - нельзя. Слова разделяются пробелами
0
 Аватар для Fixer_84
1505 / 969 / 812
Регистрация: 30.04.2016
Сообщений: 3,337
02.01.2017, 01:14
Лучший ответ Сообщение было отмечено OksanaD как решение

Решение

OksanaD, я с ними почти не работал, но, вроде, что-то получается. Подождите еще немного...

Добавлено через 46 минут
OksanaD, Я почти дорешал...подождите еще чуть-чуть...

Добавлено через 13 минут
OksanaD, держите код программы. Все, вроде, работает.

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
#include <iostream>
#include <string.h>
 
using namespace std;
 
int main()
{
    int x, y;
    char a[100];
    char b[100];
    char* first[100];
    char* second[100];
    char* str1;
    char* str2;
    cout << "Введите первую строку:" << endl;
    gets(a);
    cout << "Введите вторую строку:" << endl;
    gets(b);
    str1 = strtok(a, " ,.-");
    x = 0;
    while (str1 != NULL)
    {
        first[x] = str1;
        x++;
        str1 = strtok(NULL, " ,.-");
    }
    str2 = strtok(b, " ,.-");
    y = 0;
    while (str2 != NULL)
    {
        second[y] = str2;
        y++;
        str2 = strtok(NULL, " ,.-");
    }
    for (int i = 0; i < x; i++)
    {
        for (int j = 0; j < y; j++)
        {
            if (!strcmp(first[i], second[j]))
                strset(second[j], '*');
        }
    }
    cout << "Искомая строка:" << endl;
    for (int j = 0; j < y; j++)
    {
        cout << second[j] << " ";
    }
    cout << endl;
    system("pause");
    return 0;
}
Добавлено через 26 секунд
OksanaD, P.S. Собирал по кускам...

Добавлено через 2 минуты
OksanaD, можно добавить функцию для каждой строки (там где while), чтобы уменьшить размер кода.
1
2 / 2 / 0
Регистрация: 29.09.2015
Сообщений: 10
02.01.2017, 02:17  [ТС]
Fixer_84, да, все работает. Спасибо вам огромное!)
0
Эксперт С++
1624 / 954 / 782
Регистрация: 06.02.2016
Сообщений: 2,452
Записей в блоге: 31
02.01.2017, 10:47
Если кому понадобится со string
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
#include <iostream>
#include <set>
#include <sstream>
#include <iterator>
#include <algorithm>
#include <vector>
using namespace std;
int main() {
    string s1 {},s2 {},rep {};
    getline(cin,s1);
    getline(cin,s2);
    stringstream ss(s1);
    set<string>sal {istream_iterator<string>(ss),istream_iterator<string>()};
    ss.str()="";
    ss.clear();
    ss.str(s2);
    vector<string>v {istream_iterator<string>(ss),istream_iterator<string>()};
    replace_if(v.begin(),v.end(),[&rep,&sal]( string &s) {
        if(sal.count(s)==1) {
            rep=string(s.length(),'*');
            return true;
        } else return false;
    },rep);
    copy(v.cbegin(),v.cend(),ostream_iterator<string>(cout," "));
    return 0;
}
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
02.01.2017, 10:47
Помогаю со студенческими работами здесь

Поиск одинаковых слов
В memо1 и mеmо2 есть некоторые тексты, слова в которых разделены пробелами и знаками препинания. Как реализовать поиск одинаковых слов в...

Поиск одинаковых слов
нужно в столбце B найти одинаковые выражения состоящие из нескольких слов. В общем полностью одинаковые. Ну ли хотя бы 1 или 2 слова...

Вывод одинаковых слов
Задание: &quot;Пользователь вводит набор слов. Необходимо сформировать массив из встречающихся более 1 раза слов&quot;. Написал код, но...

Вывод 2-ух одинаковых слов
дано предложение.в нем только два слова одинаковые.найти эти слова.

Поиск одинаковых слов в файле
Я реализовал задачу(пока криво-косо, все циклы менять только ручками, если меняется обьем файла), но он выводит одинаковые слова не так,...


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

Или воспользуйтесь поиском по форуму:
6
Ответ Создать тему
Новые блоги и статьи
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Access
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
Создание Single Page Application на фреймах
krapotkin 16.11.2025
Статья исключительно для начинающих. Подходы оригинальностью не блещут. В век Веб все очень привыкли к дизайну Single-Page-Application . Быстренько разберем подход "на фреймах". Мы делаем одну. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru