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

Перед всеми глаголами в инфинитиве оканчивающихся на ить,ять,ать.Добавить частицу не перед словом

29.11.2018, 11:28. Показов 1624. Ответов 8
Метки нет (Все метки)

Author24 — интернет-сервис помощи студентам
Преобразовать исходный текст следующим образом:перед всеми глаголами в инфинитиве оканчивающихся на ить,ять,ать.Подставить перед словом частицу "не".гулять---не гулять.Заранее спасибо.
0
Лучшие ответы (1)
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
29.11.2018, 11:28
Ответы с готовыми решениями:

Перед всеми глаголами в инфинитиве вставить отрицание "не"
Выдает ошибку: "Необработанное исключение" Вот задание: Превратить начальный текст таким образом:...

Перед глаголами в инфинитиве вставить отрицание - не
Ребят, нужен хэлп) Задание - переделать исходный текст таким образом : перед глаголами в инфинитиве...

Строки: перед глаголами в инфинитиве вставить отрицание - не
Люди добрые, помогите написать код на си. задание -переделать исходный текст таким образом : перед...

Перед каждым словом добавить слово
Перед каждым словом, начинающимся с буквы 'a' добавить слово "вот".

8
2848 / 1997 / 986
Регистрация: 21.12.2010
Сообщений: 3,705
Записей в блоге: 10
29.11.2018, 12:17 2
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
#include <iostream>
#include <string>
#include <regex>
#include <clocale>
 
 
int main()
{
    setlocale(LC_CTYPE, "rus");
    std::string str{ "Гулять, вертеть, палить,кричать, гудеть.Махать" };
    std::regex rgx{"(^|[^А-Яа-я])([А-Яа-я]+[аяи]ть)(?=$|[^А-Яа-я])"};
    std::cout << std::regex_replace(str, rgx, "$1не $2") << std::endl;
}
0
3881 / 2479 / 418
Регистрация: 09.09.2017
Сообщений: 10,888
29.11.2018, 12:43 3
Код
$ cat main.cpp
#include <iostream>
#include <string>
#include <regex>
#include <clocale>
 
 
int main()
{
    setlocale(LC_CTYPE, "rus");
    std::string str{ "Гулять, вертеть, палить,кричать, гудеть.Махать" };
    std::regex rgx{"(^|[^А-Яа-я])([А-Яа-я]+[аяи]ть)(?=$|[^А-Яа-я])"};
    std::cout << std::regex_replace(str, rgx, "$1не $2") << std::endl;
}
$ g++ main.cpp -Wall -Wextra -Wpedantic
$ ./a.out 
Гуне лять, вертеть, не палить,кричне ать, гудеть.Махне ать
FAIL
1
2848 / 1997 / 986
Регистрация: 21.12.2010
Сообщений: 3,705
Записей в блоге: 10
29.11.2018, 12:59 4
Некоторые русские буквы не входят в интервал А-Яа-я. В онлайн компиляторах то же самое. Используется другая кодовая страница?
0
3881 / 2479 / 418
Регистрация: 09.09.2017
Сообщений: 10,888
29.11.2018, 14:01 5
Лучший ответ Сообщение было отмечено Алексей06 как решение

Решение

Код
$ echo $LANG
ru_RU.UTF-8
Добавлено через 37 минут
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 <stdio.h>
#include <wchar.h>
#include <wctype.h>
#include <locale.h>
 
int main(){
  setlocale(LC_ALL, "");
  wchar_t inp[1000];
  wchar_t *pos;
  char spaces[1000];
  char add_not;
  while(!feof(stdin)){
    scanf("%ls%[ \t\n\b\r(]", inp, spaces);
    add_not = 0;
    pos = wcsstr(inp, L"ть");
    if(pos != NULL)
      if(pos[-1] == L'а' || pos[-1] == L'я' || pos[-1] == L'и'){
        add_not = 1;
        for(pos+=2; pos[0]!=0; pos++){
          if(iswalpha(pos[0])){add_not = 0; break;}
        }
      }
    if(add_not)printf("не ");
    printf("%ls%s", inp, spaces);
  }
}
Код
$ ./a.out 
Гулять, вертеть, палить, кричать, гудеть. Махать
не Гулять, вертеть, не палить, не кричать, гудеть. не Махать
1
0 / 0 / 0
Регистрация: 25.11.2018
Сообщений: 21
29.11.2018, 18:02  [ТС] 6
Можно комментарии к последнему.Буду благодарен.
0
3881 / 2479 / 418
Регистрация: 09.09.2017
Сообщений: 10,888
30.11.2018, 10:29 7
Да было бы что комментировать. Вместо обычных char'ов, которые в современных системах не всегда однозначно соответствуют печатному символу (ми. многобайтные кодировки, в частности, UTF-8) использую wchar_t, где каждый элемент кодирует ровно один символ, но зато занимает 4 байта (осторожно! в windows он занимает всего 2 байта и основной задачи не выполняет, кодировка все равно получается многобайтной). Для такого типа данных используются функции, аналогичные обычным char'овским.
Для форматного ввода-вывода через printf / scanf используется строка "%ls" вместо "%s".
Регулярное выражение "%[ \t\n\b\r(]" означает ввод любого количества пробельных символов (пробел, табуляция, перевод строки, переход на символ назад, переход на начало строки) или открывающих скобок, которые тоже могут "приклеиватсья" к слову. Это сделано чтобы сохранить количество пробелов между словами. Все это вводится в обычный массив char'ов, поскольку обработка не предполагается.
Дальше функцией wcsstr() ищем вхождение подстроки "ть" (обратите внимание, что wchar_t'шные строки предваряются модификатором L). После чего проверяется предыдущий символ, который по условию должен быть 'а', 'я' или 'и'. Если это не так, то преобразований к слову применено не будет. Потом последовательно проверяются символы от найденного "ть" до конца строки и если хоть один из них будет буквой, считаем что "ть" нашлось в середине слова. Кстати, здесь ошибка: искать надо было не с начала слова, а с конца. Правда, стандартных функций для этого нет, но можно искать последний символ 'ь' в строке и проверять остальные аналогично проверке 'а', 'я', 'и'. С этим справитесь самостоятельно.
В общем-то, все.
1
0 / 0 / 0
Регистрация: 25.11.2018
Сообщений: 21
30.11.2018, 17:06  [ТС] 8
Но всё-же мне некие моменты не ясны и в программирование я новичок,хотел бы узнать что делает каждая строка.P.S Пожалуйста.
0
3881 / 2479 / 418
Регистрация: 09.09.2017
Сообщений: 10,888
01.12.2018, 09:26 9
Если я вам прокомментирую каждую строчку понятнее не станет.
Лучше посидите в обнимку с документацией самостоятельно. Что каждая строчка делает, где может упасть, для чего предназначена.
1
01.12.2018, 09:26
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
01.12.2018, 09:26
Помогаю со студенческими работами здесь

Перед каждым словом «дом» добавить слово «большой»
помогите решить пожалуйста .Составить программы, с помощью которых: - сформировать текстовый файл...

Перед каждым словом «дом» добавить слово «большой»
Составить программы, с помощью которых: - сформировать текстовый файл из строк, которые должны...

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

В рандомном массиве добавить мин. элемент перед всеми элементами, чьим делителем он будет
Сделал так , но немогу доделать никак . Диапазон массива (-50; -10). #include &lt;string&gt;...


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

Или воспользуйтесь поиском по форуму:
9
Ответ Создать тему
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2024, CyberForum.ru