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

Удалить из сообщения все слова, которые заканчиваются на заданный символ

10.01.2020, 01:59. Показов 6126. Ответов 8

Студворк — интернет-сервис помощи студентам
Дана строка, в которой содержится осмысленное текстовое сообщение.
Слова сообщения разделяются пробелами и знаками препинания. Удалить из сообщения все слова, которые заканчиваются на заданный символ
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
10.01.2020, 01:59
Ответы с готовыми решениями:

Удалить из сообщения все слова,которые заканчиваются на заданный символ
Удалить из сообщения все слова,которые заканчиваются на заданный символ

Удалить из сообщения все слова, которые заканчиваются на заданный символ
Дана строка, в которой содержится осмысленное текстовое сообщение. Слова сообщения разделяются пробелами и знаками препинания. Удалить из...

Удалить из сообщения все слова, которые заканчиваются на заданный символ
Дана строка, в которой содержится осмысленное текстовое сообщение. Слова сообщения разделяются пробелами и знаками препинания. Удалить из...

8
Модератор
 Аватар для long399
2882 / 1836 / 933
Регистрация: 16.10.2013
Сообщений: 5,240
Записей в блоге: 15
10.01.2020, 12:04
Лучший ответ Сообщение было отмечено Lina124 как решение

Решение

C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
#include <iostream>
#include <sstream>
using namespace std;
 
string deleteWordsEndingSymb(string str, char symb){
    string result = "";
    
    stringstream ss(str);
    string word;
    while (ss >> word) {
        if(word[word.length() - 1] != symb) {
            result += word + " ";
        }
    }
    return result;
}
 
int main () {
    string str = "Lorem ipsum dolor sit amet, consectetuer adipiscing elit";
    
    cout << deleteWordsEndingSymb(str, 'm');
    return 0;
}
1
848 / 651 / 323
Регистрация: 24.02.2017
Сообщений: 2,297
10.01.2020, 12:30
Лучший ответ Сообщение было отмечено Lina124 как решение

Решение

C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
#include <iostream>
#include <sstream>
using namespace std;
 
string deleteWordsEndingSymb(string str, char symb){
       stringstream ss(str);
       string word;
       while (ss >> word) {
          if(word[word.length() - 1] == symb)
              str.erase(str.find(word),word.length());
         }
       return str;
}
 
int main () {
    string str = "Lorem  ipsum dolor  sit  amet, consectetuer adipiscing elit";
 
    cout << deleteWordsEndingSymb(str, 'm');
    system("pause");
    return 0;
}
Добавлено через 1 минуту
Не зависим от количества пробелов между словами.
1
 Аватар для zayats80888
6352 / 3523 / 1428
Регистрация: 07.02.2019
Сообщений: 8,995
10.01.2020, 12:32
Цитата Сообщение от повар1 Посмотреть сообщение
Не зависим от количества пробелов между словами
а от знаков препинания по прежнему зависим
0
848 / 651 / 323
Регистрация: 24.02.2017
Сообщений: 2,297
10.01.2020, 12:34
zayats80888, А где сказано что знаки препинания удалять?
0
 Аватар для zayats80888
6352 / 3523 / 1428
Регистрация: 07.02.2019
Сообщений: 8,995
10.01.2020, 12:36
Цитата Сообщение от повар1 Посмотреть сообщение
А где сказано что знаки препинания удалять?
а я не про "удалять", а про "слова выделять"
Цитата Сообщение от Lina124 Посмотреть сообщение
Слова сообщения разделяются пробелами и знаками препинания.
0
848 / 651 / 323
Регистрация: 24.02.2017
Сообщений: 2,297
10.01.2020, 17:00
Лучший ответ Сообщение было отмечено Lina124 как решение

Решение

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 <sstream>
using namespace std;
 
string deleteWordsEndingSymb(string str, char symb){
       stringstream ss(str);
       string word;
       char *p,s[100];
       while (ss >> word) {
           strcpy(s,word.c_str());
           p=strtok(s,",:;");
 
          if(p[strlen(p)-1] == symb)
                //str.erase(str.find(word),word.length()); //знаки препинания удаляем
                str.erase(str.find(p),strlen(p)); //знаки препинания оставляем
 
         }
       return str;
}
 
int main () {
    string str = "Lorem,  ipsum: dolor;  sit:  amet, consectetuer; adipiscing elit";
 
    cout << deleteWordsEndingSymb(str, 'm');
    system("pause");
    return 0;
}
1
7438 / 5030 / 2892
Регистрация: 18.12.2017
Сообщений: 15,692
10.01.2020, 17:33
Лучший ответ Сообщение было отмечено Lina124 как решение

Решение

как вариант:
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 <sstream>
#include <string>
#include <cctype>
using namespace std;
 
string DeleteWordsLastEndingSymb(string &str, char symb)
{
    string word;
    stringstream ss(str);    
    while (ss >> word) 
    {
        size_t last=word.size()-1;
        size_t pos=str.find(word);
        if(word[last] == symb) str.erase(pos,last+1);
        if(word[last-1] == symb && ispunct(word[last])) str.erase(pos,last); 
    }
    return str;
}
 
int main () {
    string str = "Lorem,  ipsum: dolor;  sit:  amet, consectetuer; adipiscing elit";
 
    cout << DeleteWordsLastEndingSymb(str, 'm');
system("pause");
return 0;
}
0
 Аватар для zayats80888
6352 / 3523 / 1428
Регистрация: 07.02.2019
Сообщений: 8,995
10.01.2020, 17:54
Лучший ответ Сообщение было отмечено Lina124 как решение

Решение

ну тогда и вставлю вариант
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 <regex>
 
int main()
{
    std::cout << "message: ";
    std::string mess;
    std::getline(std::cin, mess);
 
    std::cout << "character: ";
    char ch;
    std::cin >> ch; 
 
    auto first = mess.cbegin();
    while (true)
    {
        std::smatch sub;
        std::regex_search(first, mess.cend(), sub, std::regex{ "[^ \t.,!?;:]+" });
        if (sub.empty()) break;
        if (*std::prev(sub[0].second) == ch)
            first = mess.erase(sub[0].first, sub[0].second);
        else
            first = sub[0].second;
    }
    std::cout << mess;
}
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
10.01.2020, 17:54
Помогаю со студенческими работами здесь

Удалить из строки все слова, которые начинаются и заканчиваются на один и тот же символ
Подскажите пожалуйста, в чем ошибка Console.WriteLine(&quot;Введите строку&quot;); string str = Console.ReadLine(); ...

Удалить из сообщения слова, заканчивающиеся на заданный символ
4. Удалить из сообщения все слова, которые заканчиваются на заданный символ.

Удалить все слова, которые начинаются и заканчиваются за одну и ту же букву
Уничтожить все слова, которые начинаются и заканчиваются за одну и ту же букву. Я написал чтобы оно мне эти слова вывело а оно и того не...

Удалить все слова в тексте, которые начинаются и заканчиваются на одну и ту же букву
Пропустил несколько занятий по дисциплине, задали написать программу с использованием строк и библиотекой &lt;string.h&gt; Пытался сам...

Удалить все элементы односвязного списка, которые содержат заданный символ
Дан односвязный список, в котором каждый элемент содержит символ. Необходимо удалить все элементы списка, которые содержат заданный символ


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

Или воспользуйтесь поиском по форуму:
9
Ответ Создать тему
Новые блоги и статьи
Новый 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? Ниже её машинный перевод. После долгих разбирательств я наконец-то вернула себе. . .
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка.
Programma_Boinc 23.12.2025
Рецензия / Мнение/ Перевод Нашел на реддите интересную статью под названием The Thinkpad X220 Tablet is the best budget school laptop period . Ниже её машинный перевод. Thinkpad X220 Tablet —. . .
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-динозавры, а новое поколение лёгких потоков. Откат?. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru