Форум программистов, компьютерный форум CyberForum.ru

Функция, возвращающая массив - C++

Восстановить пароль Регистрация
 
Shout
0 / 0 / 0
Регистрация: 27.04.2014
Сообщений: 8
27.04.2014, 19:18     Функция, возвращающая массив #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
34
35
36
37
38
39
40
41
42
#include <stdio.h>
 
const int MAX=3;
 
void creat_int (int [MAX][MAX]);
 int search (int [MAX][MAX]);
 void show(int [MAX][MAX]);
int main ()
{
    int a[MAX][MAX];
    creat_int (a);
    search (a);
    show(a);
    return 0;
}
void creat_int (int a [MAX][MAX])
{
    for (int i=0;i=MAX;i++)
        for (int j=0;j=MAX;j++)
                scanf_s("%d",&a[i][j]);
    return;
}
int search (int a [MAX][MAX])
{
    int k=0;
    int x[10];
    for(int i=0;i=MAX;i++)
    {
        bool flag=1;
        for (int j=0;j=MAX-1;j++)
            if (a[i][j]<a[i][j+1]) flag=0;
        if (flag==1) x[k]=i;
        k++;
    }
return 0;
}
void show(int x[])
{
    for (int k=0;k=10;k++)
            printf("%d ",x[k]);
    return;
}
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
_Ellen_
15 / 15 / 5
Регистрация: 28.11.2013
Сообщений: 50
27.04.2014, 19:49     Функция, возвращающая массив #2
Для начала, чтобы создать массив, придется память под него выделять динамически.
C++
1
2
3
4
cin >> n; // размер массива
int * arr = new int [n];
...
delete [ ] arr; // очистка памяти
RQdan
65 / 65 / 17
Регистрация: 26.10.2013
Сообщений: 198
27.04.2014, 22:58     Функция, возвращающая массив #3
Цитата Сообщение от Shout Посмотреть сообщение
for(int i=0;i=MAX;i++)
Почему у Вас в каждом цикле в условии присутствует "="?

Цитата Сообщение от Shout Посмотреть сообщение
if (a[i][j]<a[i][j+1]) flag=0;
Здесь необходимо: if (a[i][j]<=a[i][j+1]) flag=0;

Цитата Сообщение от Shout Посмотреть сообщение
for(int i=0;i=MAX;i++) { bool flag=1; for (int j=0;j=MAX-1;j++) if (a[i][j]<a[i][j+1]) flag=0; if (flag==1) x[k]=i; k++; }
Этот кусочек кода я бы переписал по-другому:
C++
1
2
3
4
5
6
7
8
9
10
11
12
for(int i=0;i<MAX;i++)
{
 bool flag=1;
 int j=0;
 while((j<MAX-1)&&flag) 
  if(a[i][j]<=a[i][j+1]) flag=0;
 if(flag)
 {
  x[k]=i;
  k++;
 }
}
IGPIGP
Комп_Оратор)
 Аватар для IGPIGP
6168 / 2897 / 282
Регистрация: 04.12.2011
Сообщений: 7,704
Записей в блоге: 3
27.04.2014, 22:59     Функция, возвращающая массив #4
Shout, вот так компилируется:
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
34
35
36
37
38
39
40
41
42
#include <stdio.h>
const int MAX=3;
void creat_int (int [MAX][MAX]);
 int search (int [MAX][MAX]);
 void show(int*, int);
int main ()
{
    int a[MAX][MAX];
    creat_int (a);
    search (a);
    show((int*)a, MAX*MAX);
    getchar();
    getchar();
    return 0;
}
void creat_int (int a [MAX][MAX])
{
    for (int i=0;i<MAX;i++)
        for (int j=0;j<MAX;j++)
                scanf_s("%d",&a[i][j]);
    return;
}
int search (int a [MAX][MAX])
{
    int k=0;
    int x[10];
    for(int i=0;i<MAX;i++)
    {
        bool flag=1;
        for (int j=0;j<MAX-1;j++)
            if (a[i][j]<a[i][j+1]) flag=0;
        if (flag==1) x[k]=i;
        k++;
    }
return 0;
}
void show(int x[], int sz)
{
    for (int k=0;k<sz;k++)
            printf("%d ",x[k]);
    return;
}
RQdan
65 / 65 / 17
Регистрация: 26.10.2013
Сообщений: 198
27.04.2014, 23:10     Функция, возвращающая массив #5
Цитата Сообщение от Shout Посмотреть сообщение
как создать и вернуть потом через функцию массив неизвестного размера (колличество номеров строк)?
Для примера можно так оформить:
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
void main()
{
...
int len=0;
int* x=ReturnMas(&len);//возвращается указатель на массив данных, а также в len реальный размер массива.
 
...
}
 
int* ReturnMas(*len)//функция создания и обработки массива
{
*len=10;//выщитывается реальный размер массива
int* mas=new int[*len];//создается сам массив
...
return mas;//возвращаем указатель на массив
};
Хотя в Вашем случае я бы советовал воспользоваться вектором - меньше возни будет.
Yandex
Объявления
27.04.2014, 23:10     Функция, возвращающая массив
Ответ Создать тему
Опции темы

Текущее время: 18:41. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru