|
7 / 17 / 0
Регистрация: 30.09.2021
Сообщений: 232
|
||||||
Как из результатов метода создать массив строк?30.09.2021, 23:26. Показов 7332. Ответов 99
Метки нет (Все метки)
Аналогичная проблема встретилась уже второй раз. У меня в коде есть метод, который обрабатывает строки из массива строк и создаёт из них другие строки по определённым параметрам. Я не знаю, как из результатов метода(это несколько символов) создать строку, а из строки новый массив строк. Чтобы впоследствии совершать с новыми строками другие действия. Конкретно сейчас задача: ввести массив строк. Вывести строку, в которой больше всего заглавных букв. Я создала массив (вернее, список) строк с помощью ввода с консоли. Потом написала два метода. Первый обрабатывает строки массива по очереди.Создаёт строку того же размера, что и исходная, из заглавных букв. Сравнивает с исходной и выводит совпадения, т.е. заглавные буквы.Это и есть результат этого метода.Как я понимаю, это просто несколько символов. Даже не строка. Второй метод сравнивает длину новых строк с максимумом и выводит строку с максимальной длиной, т.е. строку с наибольшим количеством заглавных букв. Вроде бы всё логично, но я не знаю, как из результатов первого метода создать массив строк, чтобы перейти ко 2 методу. Я пыталась из символов в 1 методе создать массив, чтобы потом из него создать строку. Но вместо массива выводятся квадраты по количеству символов. Пожалуйста, помогите кто-нибудь. Я решаю это уже неделю.
0
|
||||||
| 30.09.2021, 23:26 | |
|
Ответы с готовыми решениями:
99
Как проверка результатов метода Ньютона программы с настройкой «Поиск решения» Как создать Массив строк?
|
|
7 / 17 / 0
Регистрация: 30.09.2021
Сообщений: 232
|
|
| 05.10.2021, 12:33 [ТС] | |
|
xoraxax, согласна, это преинкремент, а я использую постинкремент. Сейчас я решаю совсем другую задачу, поэтому ошиблась. Так зачем он здесь?
Интеллектуальная игра - сделать рабочий код как можно короче
0
|
|
|
3639 / 2971 / 918
Регистрация: 05.07.2013
Сообщений: 14,220
|
|
| 05.10.2021, 13:35 | |
|
Отличная интеллектуальная игра - разобраться, почему же тут преинкремент
0
|
|
|
7 / 17 / 0
Регистрация: 30.09.2021
Сообщений: 232
|
|
| 05.10.2021, 13:52 [ТС] | |
|
xoraxax, пыталась. Теоретически я понимаю, что преинкремент сначала увеличивает переменную на 1, а потом выполняет операцию, а постинкремент сначала выполняет операцию, а потом увеличивает переменную на 1. Но зачем это нужно в данном случае я не понимаю. Чтобы вывести строки не в том порядке, что в исходном массиве?
0
|
|
|
Супер-модератор
|
|||||||||||||||||||||||
| 05.10.2021, 14:25 | |||||||||||||||||||||||
"оно" так не работает. Когда найдена строка с длиной, большей предыдущего максимума, эта новая длина заносится в нулевую ячейку массива num. Если одна из следующих строк имеет ту же длину, что и текущий максимум, а записано
0
|
|||||||||||||||||||||||
|
7 / 17 / 0
Регистрация: 30.09.2021
Сообщений: 232
|
|
| 05.10.2021, 15:01 [ТС] | |
|
Catstail, я знаю, что мне есть куда расти
![]() Думаю, что я тоже могу убрать метод, который создаёт строки из заглавных букв исходных строк, и внести его в основной метод. Но жалко убивать на это время. Я давно решаю совсем другие задачи. Но за идею спасибо. Я не думала, что можно решить такую задачу без методов. Позже посмотрю. По поводу декремента проверьте, ничего не теряется. При: num[ptrN]=i; ptrN++; и num[ptrN++]=i; Выводит: dRfgtYUI TYbOI GHYU При: ptrN++; num[ptrN]=i; и num[++ptrN]=i; Выводит: GHYU dRfgtYUI TYbOI Т.е. просто меняется порядок выведенных слов. Этот вопрос меня интересует, потому что я всегда, создавая массив из элементов другого массива, использую вариант num[ptrN]=i; ptrN++; Возможно, что это можно делать не во всех случаях?
1
|
|
|
3639 / 2971 / 918
Регистрация: 05.07.2013
Сообщений: 14,220
|
|
| 05.10.2021, 15:04 | |
|
т.е. просто разберись, как работает код, там 6 строчек надо понять
Добавлено через 22 секунды 2 из которых скобки
1
|
|
|
Супер-модератор
|
||
| 05.10.2021, 15:17 | ||
|
Sollita, увы, не только теряется, но иногда и лишнее захватывает:
На этих данных: AAAsgdggdfh BsBBBB AAAsgdggdfh ЯЯЯЯЯЯЯЯЯЯЯЯЯЯЯЯЯЯЯЯЯWWWWW BsBBBBHHHHHHHHHHHHHHHHWWWWW AAAsgdggdfh BsBBBB AAAsgdggdfh BsBBBB AAAsgdggdfh BsBBBB AAAsgdggdfh BsBBBB AAAsgdggdfh BsBBBB AAAsgdggdfh BsBBBB BsBBBBHHHHHHHHHHHHHHHHWWWWW AAAsgdggdfh BsBBBB AAAsgdggdfh BsBBBB AAAsgdggdfh BsBBBB AAAsgdggdfh BsBBBB AAAsgdggdfh BsBBBB AAAsgdggdfh BsBBBB AAAsgdggdfh BsBBBB AAAsgdggdfh BsBBBB Результат с num[++ptrN]=i получается: Строки с максимальным к-вом заглавных букв: ЯЯЯЯЯЯЯЯЯЯЯЯЯЯЯЯЯЯЯЯЯWWWWW BsBBBBHHHHHHHHHHHHHHHHWWWWW BsBBBBHHHHHHHHHHHHHHHHWWWWW А с num[ptrN++]=i BsBBBBHHHHHHHHHHHHHHHHWWWWW BsBBBBHHHHHHHHHHHHHHHHWWWWW AAAsgdggdfh Что неверно ("залетела" лишняя строка, а одна из правильных "проглотилась" Добавлено через 1 минуту
1
|
||
|
7 / 17 / 0
Регистрация: 30.09.2021
Сообщений: 232
|
|
| 05.10.2021, 15:32 [ТС] | |
|
Catstail, спасибо, разберусь.
0
|
|
|
1172 / 762 / 194
Регистрация: 21.05.2016
Сообщений: 1,858
|
||
| 06.10.2021, 06:09 | ||
|
Иначе будет получаться как то самое решение в 3 строчки, которое на самом деле не рабочее на граничных условиях.
0
|
||
|
7 / 17 / 0
Регистрация: 30.09.2021
Сообщений: 232
|
|
| 06.10.2021, 10:20 [ТС] | |
|
Tavashi, я знаю, спасибо
План таков:Базовые конструкции и ООП Обобщённое программирование Коллекции Исключения Потоки ввода-вывода Многопоточное программирование Введение в свинг
0
|
|
|
3582 / 2182 / 571
Регистрация: 02.09.2015
Сообщений: 5,510
|
|
| 06.10.2021, 10:54 | |
|
Tavashi, из праздного интереса: а какие граничные условия, на которых решение в "3 строчки" "ломается"?
0
|
|
|
7 / 17 / 0
Регистрация: 30.09.2021
Сообщений: 232
|
|
| 06.10.2021, 16:15 [ТС] | |
|
Arsegg, вот-вот, и из не праздного тоже
Я так и не поняла, почему "ломается"? Как вообще может быть выведена в данном случае строка с тремя заглавными буквами? Это же противоречит условию: 3 не больше 25, и не равно ему. Но теперь хоть знаю, что этого можно ожидать.
0
|
|
|
1172 / 762 / 194
Регистрация: 21.05.2016
Сообщений: 1,858
|
|
| 08.10.2021, 04:50 | |
|
0
|
|
| 08.10.2021, 10:47 | |
|
Не по теме: Tavashi, как некрасиво с темы съезжать!
0
|
|
| 08.10.2021, 12:09 | |
|
Не по теме: Arsegg, не нужно выдавать желаемое за действительное.
0
|
|
| 08.10.2021, 12:23 | |
|
Не по теме: Tavashi, если сказал А, то уж говори Б - все-таки не в зоопарке, где каждый "кукарекать" горазд.
0
|
|
| 08.10.2021, 12:31 | |
|
Не по теме: Arsegg, граничный случай - я уже написал. Это уже более чем подсказка. Тот, кто изучил стримы за пару вечеров по докам не только поймет где ошибка, но и сможет ее исправить.
0
|
|
|
7 / 17 / 0
Регистрация: 30.09.2021
Сообщений: 232
|
|
| 08.10.2021, 13:36 [ТС] | |
|
Tavashi, спасибо за разъяснения, но я думала,что Вы пишете о решении в 3 строчки в коде Catstail, о котором мы с ним писали. Код в три строчки, о котором Вы писали, я даже не пыталась разобрать, потому что стримы не изучала и не думаю, что их можно изучить за два дня
Поэтому посмотрю Ваш комментарий позже, когда буду понимать, о чём он.Может быть, Вы можете объяснить, почему ломается решение с num[ptrN++]=i или num[ptrN]=i;ptrN++; ? Я думала, что если выведу массив num, то что-нибудь пойму, но запуталась ещё больше. Вместо индексов строк с максимальным количеством заглавных букв массив num в этих случаях с какого-то момента начинает выводить нули. Почему?
0
|
|
| 08.10.2021, 14:08 | |
|
Не по теме: Tavashi, к чему витиеватые изъяснения? Если есть что сказать, то говори прямо.
0
|
|
|
1172 / 762 / 194
Регистрация: 21.05.2016
Сообщений: 1,858
|
|||||||||
| 12.10.2021, 17:45 | |||||||||
ptrN это счетчик, который должен сбрасываться в нулевое состояние в случае нахождения максимальной строки на определенном уровне итерации. Далее, следующие строки равные по длине с максимальным значением должны записываться в следующие ячейки массива. Для этого нужно сначала увеличить значение счетчика (указателя), а потом провести запись. Но не наоборот, потому что в этом случае потеряется одно из максимальных значений строки и возьмется одно лишнее, потому что вывод результатов устроен через такой цикл:
1
|
|||||||||
| 12.10.2021, 17:45 | |
|
Помогаю со студенческими работами здесь
100
Как создать двумерный массив строк
Как создать массив строк, считанных из файла? Как создать массив строк типа String^? Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
|||
|
http://iceja.net/ математические сервисы
iceja 20.01.2026
Обновила свой сайт http:/ / iceja. net/ , приделала Fast Fourier Transform экстраполяцию сигналов. Однако предсказывает далеко не каждый сигнал (см ограничения http:/ / iceja. net/ fourier/ docs ). Также. . .
|
http://iceja.net/ сервер решения полиномов
iceja 18.01.2026
Выкатила http:/ / iceja. net/ сервер решения полиномов (находит действительные корни полиномов методом Штурма).
На сайте документация по API, но скажу прямо VPS слабенький и 200 000 полиномов. . .
|
Расчёт переходных процессов в цепи постоянного тока
igorrr37 16.01.2026
/ *
Дана цепь постоянного тока с R, L, C, k(ключ), U, E, J. Программа составляет систему уравнений по 1 и 2 законам
Кирхгофа, решает её и находит:
токи, напряжения и их 1 и 2 производные при t = 0;. . .
|
Восстановить юзерскрипты Greasemonkey из бэкапа браузера
damix 15.01.2026
Если восстановить из бэкапа профиль Firefox после переустановки винды, то список юзерскриптов в Greasemonkey будет пустым.
Но восстановить их можно так.
Для этого понадобится консольная утилита. . .
|
|
Сукцессия микоризы: основная теория в виде двух уравнений.
anaschu 11.01.2026
https:/ / rutube. ru/ video/ 7a537f578d808e67a3c6fd818a44a5c4/
|
WordPad для Windows 11
Jel 10.01.2026
WordPad для Windows 11
— это приложение, которое восстанавливает классический текстовый редактор WordPad в операционной системе Windows 11. После того как Microsoft исключила WordPad из. . .
|
Classic Notepad for Windows 11
Jel 10.01.2026
Old Classic Notepad for Windows 11
Приложение для Windows 11, позволяющее пользователям вернуть классическую версию текстового редактора «Блокнот» из Windows 10. Программа предоставляет более. . .
|
Почему дизайн решает?
Neotwalker 09.01.2026
В современном мире, где конкуренция за внимание потребителя достигла пика, дизайн становится мощным инструментом для успеха бренда. Это не просто красивый внешний вид продукта или сайта — это. . .
|