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

Описать рекурсивную процедуру нахождения в массиве произведения и количества положительных элементов

21.04.2019, 04:16. Показов 1667. Ответов 28
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Не могу понять как сделать это в рекурсивном виде, помогите пож.

Добавлено через 45 секунд
массив одномерный динамический
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
21.04.2019, 04:16
Ответы с готовыми решениями:

Вычислить суммы отрицательных, произведения положительных и количества нулевых элементов в массиве
Знатоки, помогите написать программы по информатике. У меня полный завал по этой теме, а через неделю уже экзамен :( Надеюсь на вашу...

Составить рекурсивную процедуру нахождения максимального элемента в массиве
3. Составить рекурсивную процедуру нахождения максимального элемента в массиве.

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

28
57 / 40 / 21
Регистрация: 26.09.2018
Сообщений: 215
25.04.2019, 22:18
Студворк — интернет-сервис помощи студентам
А вот так нормально?:
C++
1
2
3
4
5
6
7
pair<int, int> f(int *arr, int n) {
    if (n == 1) return make_pair(arr[0] > 0 ? arr[0] : 1, arr[0] > 0);
    if (!n) return make_pair(0, 0);
    auto pr = f(arr, n - 1);
    return make_pair(pr.first * (arr[n - 1] > 0 ? arr[n - 1] : 1),
           pr.second + (arr[n - 1] > 0));
}
у меня вроде работает
0
 Аватар для Fixer_84
1505 / 969 / 812
Регистрация: 30.04.2016
Сообщений: 3,337
25.04.2019, 22:18
Kuzia domovenok, рекурсия для вашего кода из поста #8 будет вести себя так:
Миниатюры
Описать рекурсивную процедуру нахождения в массиве произведения и количества положительных элементов  
0
 Аватар для Kuzia domovenok
4268 / 3327 / 926
Регистрация: 25.03.2012
Сообщений: 12,531
Записей в блоге: 1
25.04.2019, 22:24
coder0, ну правильно, потому что ты return во всех ветвях условий функции прописываешь, а не только в if(n==0)
0
 Аватар для Fixer_84
1505 / 969 / 812
Регистрация: 30.04.2016
Сообщений: 3,337
25.04.2019, 22:27
Kuzia domovenok, вот пример, как можно использовать статическую переменную. Она подсчитывает сколько раз вызывалась функция:

C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
#include <iostream> 
 
    using namespace std;
    
void f(int n) {
    static int k = 0;
    k++;
    cout << k << "\n";
}
  
int main() {
    f(3);
    f(2);
    f(1);
    system("pause");
    return 0;
}
0
57 / 40 / 21
Регистрация: 26.09.2018
Сообщений: 215
25.04.2019, 22:30
Цитата Сообщение от Fixer_84 Посмотреть сообщение
как можно использовать статическую переменную
я думаю все знают.

Со static это уже не совсем-то и чистая рекурсия.
0
 Аватар для zayats80888
6352 / 3523 / 1428
Регистрация: 07.02.2019
Сообщений: 8,995
25.04.2019, 22:31
Fixer_84, в вашем коде из первого поста, при последнем (n==0) вызове функция возвращает результат в предыдущий вызов, а что с ним происходит дальше?
0
 Аватар для Fixer_84
1505 / 969 / 812
Регистрация: 30.04.2016
Сообщений: 3,337
25.04.2019, 22:32
Цитата Сообщение от coder0 Посмотреть сообщение
Со static это уже не совсем-то и чистая рекурсия.
Вот и мне говорят, что это неправильно. Теперь буду присваивать результат внутри функции и возвращать
0
 Аватар для zayats80888
6352 / 3523 / 1428
Регистрация: 07.02.2019
Сообщений: 8,995
25.04.2019, 22:34
Я отвечу, ничего, поэтому при раскручивании рекурсивных вызовов, каждый раз создается временный объект по умолчанию, с неинициализированными полями.
0
 Аватар для Fixer_84
1505 / 969 / 812
Регистрация: 30.04.2016
Сообщений: 3,337
25.04.2019, 22:41
Цитата Сообщение от zayats80888 Посмотреть сообщение
Fixer_84, в вашем коде из первого поста, при последнем (n==0) вызове функция возвращает результат в предыдущий вызов, а что с ним происходит дальше?
Я не знаю как это точно работает. Мне объясняли так, что она сначала раскручивается, а потом начинает закручиваться и вычислять (возвращать) результат для переданного ей параметра. На каждом шаге сверху вниз или снизу вверх. Я не знаю, я подобным образом (правда без статической переменной возвращал результат и система через тесты принимала ответ).

Добавлено через 1 минуту
zayats80888, мой компилятор этот код проглотил и выдает ответ. Я то откуда знаю какие там временные объекты создаются. Теперь буду присваивать как показали.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
25.04.2019, 22:41
Помогаю со студенческими работами здесь

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

Поиск произведения положительных четных элементов в одномерном массиве
Помогите сделать программу поиска произведения положительных четных элементов в одномерном массиве Вот код #include &lt;math.h&gt; ...

Написать рекурсивную функцию для нахождения произведения цифр натурального числа
.Написать рекурсивную функцию для нахождения произведения цифр натурального числа. С помощью этой функции найти произведения цифр пяти...

Подсчет количества отрицательных и положительных элементов в динамическом массиве
Написать функцию, которая получает указатель на динамический массив и его размер, и возвращает количество отрицательных, положительных и...

Создать функцию поиска количества положительных элементов в массиве
Даны массивы A, i = 1,...,20. и C, j = 1, ..., 20. Создать функцию поиска количества положительных элементов в массиве. Определить с...


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

Или воспользуйтесь поиском по форуму:
29
Ответ Создать тему
Новые блоги и статьи
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-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
Создание Single Page Application на фреймах
krapotkin 16.11.2025
Статья исключительно для начинающих. Подходы оригинальностью не блещут. В век Веб все очень привыкли к дизайну Single-Page-Application . Быстренько разберем подход "на фреймах". Мы делаем одну. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru