|
5 / 5 / 1
Регистрация: 15.09.2016
Сообщений: 410
|
|||||||||||||||||||||
Вызов массива, сформированной в одной функции с другой функции23.02.2020, 14:20. Показов 3557. Ответов 17
Метки нет (Все метки)
Здравствуйте! Есть разрабатываемое решение - состоящее из main.cpp и array.cpp
Main - выражает собой меню в консольном режиме по выбору типа решения и подвязки функций. У меня есть задание: Заданы массивы а1, а2, … , аn и b1, b2, … , bm Перенести в третий массив те элементы массива В, которые встречаются и в массиве А. Задаю из главного файла вызов на ввод массива А (динамического массива) и массива B (аналогично). Далее мне нужно создать, чтоб затем вызвать в головном файле, функцию, решающую саму задачу.Я решил ее назвать следующим образом: int *FindOtvet(int size3) Далее реализовать тело вызываемой функции, выделив место динам. образом в массиве С:
Помогите пожалуйста!
0
|
|||||||||||||||||||||
| 23.02.2020, 14:20 | |
|
Ответы с готовыми решениями:
17
Вызов одной функции внутри другой Как создать вызов одной функции из другой?
|
|
337 / 237 / 103
Регистрация: 26.03.2019
Сообщений: 407
|
|
| 23.02.2020, 14:51 | |
|
Вам нужно массивы A и B передавать в функцию findOtvet, вместо
int *FindOtvet(int size, int size2, int size3) должно быть int *FindOtvet(int *a, int *b, int size, int size2, int size3). Еще у вас явная проблема с size3: заранее размер третьего массива неизвестен. Есть разные варианты, как решить эту проблему. Если вы используете malloc() и free(), а не new и delete (т.е. си-шный вариант, не с++), то можно выделить size+size2, а затем, когда посчитается size3, сделать realloc(). Либо пройтись двумя циклами: в первом вычислить размер, а во втором уже заполнять массив. Но в любом случае size3 должен возвращаться из этой функции, так что стоит передавать его по ссылке или указателю: int *FindOtvet(int *a, int *b, int size, int size2, int *size3). При обращении к size3 в функции нужно будет разыменовывать: (*size3)++;, например.В main(если я правильно понимаю, что h - это размер третьего массива) вызываем затем функцию так: C = FindOtvet(a, b, n, m, &h);
1
|
|
|
5 / 5 / 1
Регистрация: 15.09.2016
Сообщений: 410
|
||||||
| 23.02.2020, 15:12 [ТС] | ||||||
|
Здравствуйте! Пытаюсь собрать ваши рекомендации в одно едино. Получается пока плохо:
Запутался
0
|
||||||
|
337 / 237 / 103
Регистрация: 26.03.2019
Сообщений: 407
|
|||||||||||||
| 23.02.2020, 15:44 | |||||||||||||
|
Пока все хорошо(саму логику формирования массива не смотрю пока). Вывод массива C лучше оформить отдельной функцией, но для начала можно проверить и так, как есть, что все работает.
size3 нужно инициализировать нулем; i - счетчик в массиве b, к c можно обращаться c[size3] = ...; a[i] = 0; - для a у нас j: a[j] = 0; a и b в результате работы испортятся, так что если предполагается их дальнейшее использование, нужно делать копии или выбирать другой алгоритм.
1
|
|||||||||||||
|
5 / 5 / 1
Регистрация: 15.09.2016
Сообщений: 410
|
||||||
| 23.02.2020, 15:56 [ТС] | ||||||
|
В конечном счете возникает недопустимость косвенного обращения недопустимость косвенного обращения (в функции аргумент не определен через *, и снова..необъявленный идентификатор c.
0
|
||||||
|
337 / 237 / 103
Регистрация: 26.03.2019
Сообщений: 407
|
|||||||||||||
| 23.02.2020, 16:02 | |||||||||||||
c проверьте во всей функции, какие-то они там разные, судя по всему русская С местами)
1
|
|||||||||||||
|
5 / 5 / 1
Регистрация: 15.09.2016
Сообщений: 410
|
|||||||||||
| 23.02.2020, 16:15 [ТС] | |||||||||||
|
Спасибо, что помогаете! Дополнил. Однако, при вызове printf(" Результирующий массив равен: ");
d = FindOtvet(a, b, n, m, &h); (переименовал c на d во избежание таких проблем), код начинает вести неадекватно - не реализовывая должным образом функцию ввода массива B, как это было ранее.
0
|
|||||||||||
|
337 / 237 / 103
Регистрация: 26.03.2019
Сообщений: 407
|
|
| 23.02.2020, 16:24 | |
|
1
|
|
|
5 / 5 / 1
Регистрация: 15.09.2016
Сообщений: 410
|
||||||
| 23.02.2020, 16:30 [ТС] | ||||||
|
Отлично, еще раз спасибо. Остается..похоже, самое интересное. Перенести в третий массив (d) те элементы массива В, которые встречаются и в массиве А. Алгоритм я составил. Подозрение на его неправильность есть, в частности, в конечных итерациях + на вывод.
0
|
||||||
|
337 / 237 / 103
Регистрация: 26.03.2019
Сообщений: 407
|
|||||||||||
| 23.02.2020, 16:37 | |||||||||||
|
Там осталась парочка уже отмеченных ошибок, добавилась пара новых, плюс по самому алгоритму - обнуление и элементов a, и b приведет к тому, что в результирующий массив попадут нули.
Должно быть как-то так:
А, в общем-то даже не нужно складывать размеры: мы же только из b копируем, он и определяет максимум:
Но алгоритм все равно еще требует доработки: в массиве B может быть нулевой элемент, которого изначально нет в массиве A. В этом случае алгоритм отработает с ошибкой.
0
|
|||||||||||
|
5 / 5 / 1
Регистрация: 15.09.2016
Сообщений: 410
|
||||||
| 23.02.2020, 16:45 [ТС] | ||||||
|
Перенести в третий массив (d) те элементы массива В, которые встречаются и в массиве А.
Должен был быть один элемент в массиве (D) с значением в 2. А получилось..вовсе 21.
0
|
||||||
|
337 / 237 / 103
Регистрация: 26.03.2019
Сообщений: 407
|
|
| 23.02.2020, 16:50 | |
Сообщение было отмечено slavek777 как решение
Решение
Почему? 2 и 1, оба подходят, а пробела в выводе нет, так что они слились)
0
|
|
|
5 / 5 / 1
Регистрация: 15.09.2016
Сообщений: 410
|
|
| 23.02.2020, 16:59 [ТС] | |
|
Понял! Еще раз благодарю - огромное спасибо за помощь, с форматированием, надеюсь, уже разберусь. То есть если: В массиве B может быть нулевой элемент, которого изначально нет в массиве A" => можно ввести условный оператор, проверяющий факт несовпадения нулевого элемента в этих массивах, а затем добавить в массив Д.
0
|
|
|
337 / 237 / 103
Регистрация: 26.03.2019
Сообщений: 407
|
|
| 23.02.2020, 17:14 | |
|
Я бы ничего не обнуляла, а просто дополнительно проверяла, что элемент еще не встречался в массиве B, если нужно переносить только уникальные. А может быть и не нужно проверять уникальность - в задании ведь об этом ничего нет.
1
|
|
|
5 / 5 / 1
Регистрация: 15.09.2016
Сообщений: 410
|
|
| 23.02.2020, 17:22 [ТС] | |
|
Вы еще говорили про "замусоренность" a и b после результатов работы - а если затем использовать free(), это вопрос целиком будет решен? Или необходимо все же обнулить сами переменные. Я планирую использовать тот же алгоритм и эту же функцию, но при условии, что данные будут взяты с файла/сформированы через рэндом. (для этого будут написаны формулы).
0
|
|
|
337 / 237 / 103
Регистрация: 26.03.2019
Сообщений: 407
|
|
| 23.02.2020, 17:38 | |
|
Я имела в виду, что обнуляя элементы, вы теряете изначальные массивы(по очевидной причине - элементы становятся нулями). Если они больше не нужны, то и ладно, но если дальше с ними еще что-то нужно делать, то, конечно, нужно их сохранить.
free() нужно в любом случае, чтобы освободить динамическую память, когда она больше не нужна.
0
|
|
|
5 / 5 / 1
Регистрация: 15.09.2016
Сообщений: 410
|
|
| 23.02.2020, 17:42 [ТС] | |
|
А какой наиболее элегантный вариант сохранения массивов исходных (хоть мне это и не нужно)? Сплошное копирование через цикл for в дублирующие новосозданные массивы?
0
|
|
|
337 / 237 / 103
Регистрация: 26.03.2019
Сообщений: 407
|
|
| 23.02.2020, 17:51 | |
|
Можно просто использовать алгоритм без обнуления(а вообще эта задача очень хорошо решается через множества). А если все-таки нужно менять исходные значения, то да, сделать копию.
0
|
|
| 23.02.2020, 17:51 | |
|
Помогаю со студенческими работами здесь
18
можно ли в с++ вызвать переменную из одной функции в другую т.е. мы переменну задали в одной функции а использовали в другой... и как это реализовать? Вызов функции внутри другой функции с передачей локальной переменной по ссылке
Вызов функции из другой функции после нажатия на кнопку
Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
|||
|
Очистка реквизитов документа при копировании
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
Эта мне ментальная установка, что вот прямо сейчас, мол, мне для полного счастья не хватает (нужное вписать), и когда я этого достигну - тогда и полный кайф. Одна из самых сильных ловушек на пути. . . .
|
Использование значений реквизитов справочника в документе, с определенными условиями и правами
Maks 07.04.2026
1. Контроль срока действия договора
Алгоритм из решения ниже реализован на примере нетипового документа "ЗаявкаНаРаботу", разработанного в конфигурации КА2.
Задача: уведомлять пользователя, если. . .
|