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

Дан текст, состоящий из предложений, разделенных знаками препинания из набора «. ? !»

20.04.2021, 00:08. Показов 1914. Ответов 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<set>
#include <algorithm>
#include <string>
#include<vector>
#include<numeric>
 
using namespace std;
 
int main() {
    setlocale(LC_ALL, "rus");
    set<string> pov, vv;
    int pos = 0, pos1 = 0, k, k1;
    string razd = ".!?", text = "Восклицательное_Предложение!_Вопросительное_предложение?_Повествовательное_Предложение_одно._Одно!";
    cout << text << endl;
    for (int pos = 0; pos < text.length(); pos+=k+2) {
        k = text.find_first_of(razd, pos);
        string temp = text.substr(pos, k - pos);
        char c = text[k];
        temp.insert(k, "_");
        for (int pos1 = 0; pos1 < temp.length(); pos1+=k1) {
            k1= temp.find_first_of("_", pos1);
            string word = temp.substr(pos1, k1-pos1);
            transform(word.begin(), word.end(), word.begin(), tolower);
            switch (c) {
            case '.': 
                pov.insert(word);
            case '!':
                vv.insert(word);
            case '?':
                vv.insert(word);
            }
            k1 += 1;
        }
        k1 = 0;
    }
    vector<string> res;
    set_difference(pov.begin(), pov.end(), vv.begin(), vv.end(), res.begin());
    for (vector<string>::iterator iter = res.begin(); iter != res.end(); iter++) {
        cout << *iter << " ";
    }
    system("pause");
    return 0;
}
Миниатюры
Дан текст, состоящий из предложений, разделенных знаками препинания из набора «. ? !»  
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
20.04.2021, 00:08
Ответы с готовыми решениями:

Дан текст из слов, разделенных знаками препинания
Дан текст из слов, разделенных знаками препинания. Определить, какое из слов встречается в строке раньше: с максимальным количеством...

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

Дан массив символов, состоящий из предложений, разделенных точками
Дан массив символов, состоящий из предложений, разделенных точками. Напишите программу, производящую следующее форматирование: а) после...

2
 Аватар для Coffeini
753 / 370 / 133
Регистрация: 01.02.2020
Сообщений: 1,096
Записей в блоге: 1
20.04.2021, 00:17
А что он должен делать?
Цитата Сообщение от coronaborealis Посмотреть сообщение
set<string> pov, vv;
Почему в качестве множества используется именно set?
Цитата Сообщение от coronaborealis Посмотреть сообщение
k
Где определение конца первого предложения?
0
 Аватар для SmallEvil
4086 / 2975 / 813
Регистрация: 29.06.2020
Сообщений: 11,000
20.04.2021, 03:21
coronaborealis, в примере кода текст не содержит обычных предложений - а значит требуемых слов не будет.

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
#include <iostream>
#include <set>
#include <algorithm>
#include <string>
 
using namespace std;
 
int main() {
    set<string> simple_w;
    set<string> filtered_w;
    set<string> * lever;
    size_t pos_b = 0, pos_e = 0; // начало предложения
    size_t wpos_b, wpos_e;
    string sep = ".!?", sep_s = ".!? ";
    string word;
    string text = "Simple text sentence. Are you ready? simple task!";
    cout << text << endl;
    while( (pos_e=text.find_first_of(sep, pos_b))!=string::npos)
    {
        if (text[pos_e] == '.')
            lever = &simple_w;
        else
            lever = &filtered_w;
        wpos_b = pos_b;
        while(wpos_b<pos_e)
        {
            wpos_b = text.find_first_not_of(sep_s, wpos_b);
            if (wpos_b>=pos_e)
                break;
            wpos_e = text.find_first_of(sep_s, wpos_b);
            word.assign(text.substr(wpos_b, wpos_e-wpos_b));
            for (auto & ch:word)
                ch = tolower(ch);
            lever->insert(word);
            wpos_b = wpos_e + 1;
        }
        pos_b = pos_e + 1;
    }
    set<string> result;
    set_difference(simple_w.begin(), simple_w.end(), filtered_w.begin(), filtered_w.end(), std::inserter(result, result.end()) );
    for (auto & w:result)
        cout<<w<<" ";
    return 0;
}
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
20.04.2021, 03:21
Помогаю со студенческими работами здесь

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

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

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

Дан текст, состоящий из строчных латинских букв и знаков препинания.
Дан текст, состоящий из строчных латинских букв и знаков препинания. Определить, какие гласные буквы (a,e,i,o,u) встретились в этом тексте...

Форматирование текста. Дан текст, состоящий из предложений, разделяемых точками
Форматирование текста. Дан текст, состоящий из предложений, разделяемых точками. Напишите программу, производящую следующее форматирование:...


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

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Новые блоги и статьи
Подстановка значения реквизита справочника в табличную часть документа
Maks 10.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2. Задача: при выборе сотрудника (справочник Сотрудники) в ТЧ документа. . .
Очистка реквизитов документа при копировании
Maks 09.04.2026
Алгоритм из решения ниже применим как для типовых, так и для нетиповых документов на самых различных конфигурациях. Задача: при копировании документа очищать определенные реквизиты и табличную. . .
модель ЗдравоСохранения 8. Подготовка к разному выполнению заданий
anaschu 08.04.2026
https:/ / github. com/ shumilovas/ med2. git main ветка * содержимое блока дэлэй из старой модели теперь внутри зайца новой модели 8ATzM_2aurI
Блокировка документа от изменений, если он открыт у другого пользователя
Maks 08.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа, разработанного в конфигурации КА2. Задача: запретить редактирование документа, если он открыт у другого пользователя. / / . . .
Система безопасности+живучести для сервера-слоя интернета (сети). Двойная привязка.
Hrethgir 08.04.2026
Далее были размышления о системе безопасности. Сообщения с наклонным текстом - мои. А как нам будет можно проверить, что ссылка наша, а не подделана хулиганами, которая выбросит на другую ветку и. . .
Модель ЗдрввоСохранения 7: больше работников, больше ресурсов.
anaschu 08.04.2026
работников и заданий может быть сколько угодно, но настроено всё так, что используется пока что только 20% kYBz3eJf3jQ
Дальние перспективы сервера - слоя сети с космологическим дизайном интефейса карты и логики.
Hrethgir 07.04.2026
Дальнейшее ближайшее планирование вывело к размышлениям над дальними перспективами. И вот тут может быть даже будут нужны оценки специалистов, так как в дальних перспективах всё может очень сильно. . .
Горе от ума
kumehtar 07.04.2026
Эта мне ментальная установка, что вот прямо сейчас, мол, мне для полного счастья не хватает (нужное вписать), и когда я этого достигну - тогда и полный кайф. Одна из самых сильных ловушек на пути. . . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru