Форум программистов, компьютерный форум, киберфорум
Наши страницы

С++ для начинающих

Войти
Регистрация
Восстановить пароль
 
V0vKA
0 / 0 / 0
Регистрация: 22.04.2013
Сообщений: 26
#1

вывод массива из функции - C++

08.05.2013, 21:11. Просмотров 990. Ответов 4
Метки нет (Все метки)

как можно передать массив optimal из функции

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
27
28
29
#include<iostream>
using namespace std;
const int m1=1,m2=2,m3=3,r1=30,r2=60,r3=80;
const int massa=4;
 
int recurs(int); 
int main()
{
 int itog;
  itog=recurs(massa);
  cout<<itog;
    system("pause");
    return 0;
}
int recurs(int sv)
{int F=0;
 int Z=0;
 int m=0;
int optimal[massa+1];
    if(sv-m3>=0){Z=r3+recurs(sv-m3);}
    if(Z>F){F=Z;m=m3;}
    if(sv-m2>=0){Z=r2+recurs(sv-m2);}
    if(Z>F){F=Z;m=m2;}
    if(sv-m1>=0){Z=r1+recurs(sv-m1);}
    if(Z>F){F=Z;m=m1;}
    optimal[sv]=m;
    
    return F;
}
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
08.05.2013, 21:11
Здравствуйте! Я подобрал для вас темы с ответами на вопрос вывод массива из функции (C++):

Функции двумерного массива. Транспонировать матрицу через ввод вывод функции двумерного массива. - C++
Транспонировать матрицу через ввод вывод функции двумерного массива.Сначала вывести ее,а потом провести транспонирование.

Открытые функции класса: ввод массива, вывод массива, определение длины вектора - C++
Данные класса: массив N(10). Открытые функции класса: ввод массива, вывод массива, определение длины вектора. Длина массива определяется...

Вывод массива из функции - C++
Доброй ночи. Подскажите пожалуйста как вывести массив из функции, не могу сообразить как это сделать. using namespace std; int...

Вывод массива из функции С++ - C++
Вобщем, нашел код в интернете (консольное приложение) алгоритм Дейкстра #include&lt;iostream.h&gt; #include&lt;string.h&gt; #include&lt;stdio.h&gt; ...

Вывод массива из функции с рекурсией - C++
Подскажите почему функция сортировки void vyvod_hoara не выводит результат сортировки после работы функции void hoara #include...

Ввод и вывод массива.функции и указатели - C++
Требуется осуществить ввод нескольких двумерных массивов(3 шт) с помощью функций и указателей. Совершенно ничего не могу понять и все, на...

4
Кудаив
329 / 406 / 24
Регистрация: 27.05.2012
Сообщений: 1,168
Завершенные тесты: 2
08.05.2013, 22:48 #2
есть два варианта
1) создать массив в майне потом передать его в функцию, предварительно усовершенствовав функцию
C++
1
int recurs(int* array, int size, int sv)
соответственно все изменения массива в функции останутся в массиве
2) создать динамический массив в функции и вернуть указатель на него
1
Tulosba
:)
Эксперт С++
4397 / 3233 / 297
Регистрация: 19.02.2013
Сообщений: 9,045
08.05.2013, 23:26 #3
...или возвращать std::vector<int>.
С другой стороны, судя по коду (если не брать рекурсивные вызовы), заполняется только одна ячейка и ее значение никак не используется.
0
V0vKA
0 / 0 / 0
Регистрация: 22.04.2013
Сообщений: 26
08.05.2013, 23:31  [ТС] #4
спасибо сделал первым способом все работает.

Добавлено через 1 минуту
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
27
28
29
30
31
32
33
#include<iostream>
using namespace std;
const int m1=1,m2=2,m3=3,r1=30,r2=60,r3=80;
const int massa=15;
 
int recurs(int, int optimal[massa+1]); 
int main()
{int optimalnoe[massa+1];
 int itog;
  itog=recurs(massa,optimalnoe);
  cout<<itog;
  for(int i=1;i<=massa;i++)
  {
      cout<<optimalnoe[i]<<endl;
  }
    system("pause");
    return 0;
}
int recurs(int sv,int optimal[massa+1])
{int F=0;
 int Z=0;
 int m=0;
 
    if(sv-m3>=0){Z=r3+recurs(sv-m3,optimal);}
    if(Z>F){F=Z;m=m3;}
    if(sv-m2>=0){Z=r2+recurs(sv-m2,optimal);}
    if(Z>F){F=Z;m=m2;}
    if(sv-m1>=0){Z=r1+recurs(sv-m1,optimal);}
    if(Z>F){F=Z;m=m1;}
    optimal[sv]=m;
    
    return F;
}
0
Tulosba
:)
Эксперт С++
4397 / 3233 / 297
Регистрация: 19.02.2013
Сообщений: 9,045
08.05.2013, 23:59 #5
Цитата Сообщение от V0vKA Посмотреть сообщение
for(int i=1;i<=massa;i++) { cout<<optimalnoe[i]<<endl; }
Индексация массивов начинается с нуля. Имейте в виду, когда такие циклы пишите.
0
08.05.2013, 23:59
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
08.05.2013, 23:59
Привет! Вот еще темы с ответами:

С помощью рекурсивной функции осуществить вывод на экран элементов одномерного массива - C++
С помощью рекурсивной функции осуществить вывод на экран элементов одномерного массива

Создать двухмерный массив. Ввод вывод массива вынести в отдельные функции - C++
Создать двумерный массив размером m x n. Заполнить его случайными числами от 0 до 10. Вывести массив на экран. Найти произведение чётных...

Три функции (ввод значений элементов массива, вывод, сравнение двух массивов) - C++
Написать программу с тремя функциями: ввод значений элементов массива целых (возможно,значение получают не все элементы), вывод, сравнение...

Создать динамический массив. ввод,вывод и обработку элементов массива реализовать через функции - C++
создать динамический массив. ввод,вывод и обработку элементов массива реализовать через функции


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

Или воспользуйтесь поиском по форуму:
5
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru