|
0 / 0 / 0
Регистрация: 29.03.2013
Сообщений: 8
|
||||||
Удаление каждого нечетного слова02.04.2013, 12:37. Показов 1070. Ответов 3
Метки нет (Все метки)
Доброго времени суток. Помогите изменить программу. Дана программа, которая переворачивает каждое нечетное слово. Нужно это слово удалить.
Добавлено через 19 часов 52 минуты Есть пояснение к программе, я не могу понять. Первая часть программы (до строки int word_count=0) обеспечивает удаление «лишних» пробелов. По окончании этой части строка os не содержит «лишних» пробелов. Теперь остается только перевернуть каждое нечетное слово этой строки. Для подсчета слов добавляется переменная word_count, которая первоначально устанавливается равной 0. Затем начинается цикл for, который перебирает все символы строки os. Заметьте, что он не содержит действия, выполняемого после очередной итерации, например, действия вида i++. Затем проверяется, что очередной символ os[i] не является пробелом. Если же он является пробелом, то выполняется i++, что обеспечивает переход к следующему символу строки. Когда os[i] не является пробелом, то тогда начинается еще один цикл for, который не содержит действий внутри цикла, что выражается в отсутствии выражений внутри соответствующий фигурных скобок. Этот цикл обеспечивает поиск последнего символа текущего слова. Этот цикл последовательно перебирает символы до тех пор, пока не встретится символ пробела или символ с кодом 0. Поэтому по окончании данного цикла переменная j – это индекс символа, идущего сразу после текущего слова. Тогда i – это индекс первого символа текущего слова, а (j-1) – это индекс последнего символа текущего слова. После данного цикла for выполняется проверка на нечетность слова. Для этого сначала счетчик слов word_count увеличивается на 1 (++word_count), так как выделено очередное слово. Затем полученное значение проверяется на нечетность. В итоге условие нечетности слова можно представить как ((++word_count)%2==1). Если слово является нечетным, то тогда данное слово переворачивается. Для этого используется еще один цикл for, в котором перебираются символы первой половины текущего слова, то есть от символа с индексом i до символа с индексом (i+j-1)/2. При этом используется дополнительная переменная k, которая и осуществляет перебор символов. Внутри указанного цикла обеспечивается обмен местами символа из первой половины слова с символом, расположенным во второй половине слова на месте с индексом ((j-1)-(k-i)), симметричном относительно центра слова. Для такого обмена вводится буферная переменная ch, которая обеспечивает временное хранение символа при обмене. В итоге нечетное слово будет перевернуто. Наконец, обеспечивается перемещение текущего индекса на позицию сразу после рас-смотренного слова, что обеспечивается простым присвоением i=j. Таким образом, каждое нечетное слово в строке os будет перевернуто. Полученная выходная строка выводится с помощью функции printf. Я предполагаю нужно изменить 21, 22, 23 строчки.
0
|
||||||
| 02.04.2013, 12:37 | |
|
Ответы с готовыми решениями:
3
Удаление каждого четного слова в строке. Подсчёт количества чисел, удаление каждого второго слова и слов из латинских букв Найти сумму положительных элементов каждого четного столбца и произведение отрицательных элементов каждого нечетного столбца |
|
0 / 0 / 0
Регистрация: 29.03.2013
Сообщений: 8
|
|
| 08.04.2013, 18:56 [ТС] | |
|
Актуально
0
|
|
|
0 / 0 / 0
Регистрация: 29.03.2013
Сообщений: 8
|
|
| 15.04.2013, 08:51 [ТС] | |
|
Актуально
0
|
|
|
0 / 0 / 0
Регистрация: 29.03.2013
Сообщений: 8
|
|
| 16.05.2013, 14:49 [ТС] | |
|
Актуально
0
|
|
| 16.05.2013, 14:49 | |
|
Помогаю со студенческими работами здесь
4
Напечатать все различные слова и для каждого слова указать количество повторений Преобразовать строку таким образом, чтобы цифры каждого слова были перенесены в конец слова Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
|||
|
Модель микоризы: классовый агентный подход 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?
Ниже её машинный перевод.
После долгих разбирательств я наконец-то вернула себе. . .
|
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 открывается в домашней директории. . .
|