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

Ошибка в аргументе функции - C++

Восстановить пароль Регистрация
 
MurderKnot
-98 / 0 / 0
Регистрация: 15.10.2013
Сообщений: 32
17.10.2013, 14:26     Ошибка в аргументе функции #1
Доброго времени суток. В университете дали такое задание:
Составить программу на основе ветвления, концепция задачи такова:
(Преподаватель очень весёлый человек, так что не удивляйтесь)
Задан двумерный динамический массив, задающий высоты платформ, по которым прыгает "жук".
Количество платформ задано размерами массива.
Он должен добраться к "жучихе" и собрать для неё цветы, количество которых находится по формуле через высоту
(a[n][m]-a[n][m+1] - для прыжка в вниз и a[n][m]-a[n+1][m] - для прыжка вправо).


Написал вот такую программу:

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
43
44
45
46
47
48
49
50
51
52
53
54
#include <iostream>
#include <algorithm>
#include <time.h>
 
using namespace std;
 
int step_right(int **a,int n,int m){
    return a[n][m]-a[n][m+1];
}
 
int step_down(int **a, int n, int m){
    return a[n][m]-a[n][m+1];
}
 
int not_very_smart_one_step(int **a,int i, int j){
    int flowers = 0;
    int m = 0;
    int n = 0;
    while ((n!=i)&&(m!=j)){
        if (m==j-1){
            flowers+=step_right(a,n,m);
            n++;
        }
        else{
            if (n==i-1){
                flowers+=step_down(a,n,m);
                m++;
            }
            else{
                flowers+=(step_right(a,n,m)>step_down(a,n,m))?step_right(a,n,m):step_down(a,n,m);
                (step_right(a,n,m)>step_down(a,n,m))?n++:m++;
            }
        }
    }
    return flowers;
}
 
int main(){
  setlocale(LC_ALL, "Russian");
  int i, j;
  cout<<"Введите размер площадки ..."<<endl;
  cin>>i>>j;
  int mas[i][j];
  cout<<"высоты платформ:"<<endl;
  srand(time(NULL));
  for (int x = 0; x<5; x++){
    for (int y = 0; y<5; y++){
      mas[x][y]=rand()%100;
      cout<<mas[x][y]<<" ";
    }
  }
cout<<not_very_smart_one_step(mas,i,j)<<endl; // в этой строке выдаёт ошибку - ошибка: cannot convert 'int (*)[(((sizetype)(((ssizetype)j) + -1)) + 1)]' to 'int**' for argument '1' to 'int not_very_smart_one_step(int**, int, int)'                                                                      
cout<<endl;
}
И теперь собственно вопрос: в чём заключается ошибка и как её исправить?

P.S. Пишу в Qt creator как консольный проект С++
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
MurderKnot
-98 / 0 / 0
Регистрация: 15.10.2013
Сообщений: 32
17.10.2013, 14:28  [ТС]     Ошибка в аргументе функции #2
Ошибка в аргументе функции
Rivory
146 / 112 / 2
Регистрация: 15.01.2013
Сообщений: 266
17.10.2013, 14:44     Ошибка в аргументе функции #3
Объявите матрицу в динамической памяти
C++
1
2
3
4
  cin >> i >> j;
    int** mas;
    mas = new int*[i];
    for(int a = 0; a < i; ++a) mas[a] = new int[j];
Вместо
C++
1
int mas[i][j];
И там ниже в циклах
C++
1
2
  for (int x = 0; x<5; x++){
    for (int y = 0; y<5; y++){
Наверное все же
C++
1
2
  for (int x = 0; x<i; x++){
    for (int y = 0; y<j; y++){
?
dzrkot
zzzZZZ...
 Аватар для dzrkot
516 / 346 / 53
Регистрация: 11.09.2013
Сообщений: 1,977
17.10.2013, 14:48     Ошибка в аргументе функции #4
Цитата Сообщение от MurderKnot Посмотреть сообщение
Доброго времени суток. В университете дали такое задание:
Составить программу на основе ветвления, концепция задачи такова:
(Преподаватель очень весёлый человек, так что не удивляйтесь)
Задан двумерный динамический массив, задающий высоты платформ, по которым прыгает "жук".
Количество платформ задано размерами массива.
Он должен добраться к "жучихе" и собрать для неё цветы, количество которых находится по формуле через высоту
(a[n][m]-a[n][m+1] - для прыжка в вниз и a[n][m]-a[n+1][m] - для прыжка вправо).


Написал вот такую программу:

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
43
44
45
46
47
48
49
50
51
52
53
54
#include <iostream>
#include <algorithm>
#include <time.h>
 
using namespace std;
 
int step_right(int **a,int n,int m){
    return a[n][m]-a[n][m+1];
}
 
int step_down(int **a, int n, int m){
    return a[n][m]-a[n][m+1];
}
 
int not_very_smart_one_step(int **a,int i, int j){
    int flowers = 0;
    int m = 0;
    int n = 0;
    while ((n!=i)&&(m!=j)){
        if (m==j-1){
            flowers+=step_right(a,n,m);
            n++;
        }
        else{
            if (n==i-1){
                flowers+=step_down(a,n,m);
                m++;
            }
            else{
                flowers+=(step_right(a,n,m)>step_down(a,n,m))?step_right(a,n,m):step_down(a,n,m);
                (step_right(a,n,m)>step_down(a,n,m))?n++:m++;
            }
        }
    }
    return flowers;
}
 
int main(){
  setlocale(LC_ALL, "Russian");
  int i, j;
  cout<<"Введите размер площадки ..."<<endl;
  cin>>i>>j;
  int mas[i][j];
  cout<<"высоты платформ:"<<endl;
  srand(time(NULL));
  for (int x = 0; x<5; x++){
    for (int y = 0; y<5; y++){
      mas[x][y]=rand()%100;
      cout<<mas[x][y]<<" ";
    }
  }
cout<<not_very_smart_one_step(mas,i,j)<<endl; // в этой строке выдаёт ошибку - ошибка: cannot convert 'int (*)[(((sizetype)(((ssizetype)j) + -1)) + 1)]' to 'int**' for argument '1' to 'int not_very_smart_one_step(int**, int, int)'                                                                      
cout<<endl;
}
И теперь собственно вопрос: в чём заключается ошибка и как её исправить?

P.S. Пишу в Qt creator как консольный проект С++
а компилятор пропустил int mas[i][j] ?) странно)

вообще если ты вводишь размер массива с клавы то надо создавать указатель на массив, а потом указатель на массив указателей, т.е. выделять память при помощт new, примерно так:
cin>>i;
int a*=new int[i];
int **B=new *int[j];
и дальше заполнять массив а(причем его нужно заполнять в цикле, т.е. в цикле каждый раз создавать int *a=new int[];, после чего заполнять массив b адресами массива а, а чтобы обращаться к массиву b , придётся делать так (*b[j]+i)
MurderKnot
-98 / 0 / 0
Регистрация: 15.10.2013
Сообщений: 32
17.10.2013, 15:49  [ТС]     Ошибка в аргументе функции #5
dzrkot, зачем же делать так? Это долго и запутанно, компилятор это пропускает, мало того у меня есть рабочие программы, основанные на моём принципе. Так что я думаю проблема не в этом.

Добавлено через 10 минут
Спасибо за совет, сейчас попробую
dzrkot
zzzZZZ...
 Аватар для dzrkot
516 / 346 / 53
Регистрация: 11.09.2013
Сообщений: 1,977
17.10.2013, 16:01     Ошибка в аргументе функции #6
Цитата Сообщение от MurderKnot Посмотреть сообщение
dzrkot, зачем же делать так? Это долго и запутанно, компилятор это пропускает, мало того у меня есть рабочие программы, основанные на моём принципе. Так что я думаю проблема не в этом.
ну так правильно...надо понимать как писать проги правильно...
почему компилятор это пропускает я беспонятия, мб он сам выделяет память под это дело o_0, это не есть нормально...

выложите плз пример такой работающей проги, интересно посмотреть
...хм...мб это описано в #include <algorithm> ...
alsav22
5282 / 4801 / 442
Регистрация: 04.06.2011
Сообщений: 13,587
17.10.2013, 16:13     Ошибка в аргументе функции #7
Цитата Сообщение от dzrkot Посмотреть сообщение
почему компилятор это пропускает я беспонятия
От компилятора зависит. gcc/mingw допускают такое( variable-length array) (хотя не стандарт).
dzrkot
zzzZZZ...
 Аватар для dzrkot
516 / 346 / 53
Регистрация: 11.09.2013
Сообщений: 1,977
17.10.2013, 16:15     Ошибка в аргументе функции #8
Цитата Сообщение от alsav22 Посмотреть сообщение
От компилятора зависит. gcc/mingw допускают такое( variable-length array) (хотя не стандарт).
так а они полноценная альтернатива всем этим **a=new int*[size]; ? ...или просто пропускают, но косяки в дальнейшем с обращением к несуществующим областям памяти например или что-нибудь в этом роде...?
alsav22
5282 / 4801 / 442
Регистрация: 04.06.2011
Сообщений: 13,587
17.10.2013, 16:21     Ошибка в аргументе функции #9
Цитата Сообщение от dzrkot Посмотреть сообщение
так а они полноценная альтернатива всем этим **a=new int*[size]; ?
Это не альтернатива, потому что массив на стеке и в динамической памяти не одно и тоже.
Цитата Сообщение от dzrkot Посмотреть сообщение
или просто пропускают, но косяки в дальнейшем с обращением к несуществующим областям памяти например или что-нибудь в этом роде...?
Косяков не будет, реализация так сделана.
dzrkot
zzzZZZ...
 Аватар для dzrkot
516 / 346 / 53
Регистрация: 11.09.2013
Сообщений: 1,977
17.10.2013, 16:29     Ошибка в аргументе функции #10
Цитата Сообщение от alsav22 Посмотреть сообщение
Это не альтернатива, потому что массив на стеке и в динамической памяти не одно и тоже.
не очень представляю в чём может выразиться эта разница...т.е. последствия
alsav22
5282 / 4801 / 442
Регистрация: 04.06.2011
Сообщений: 13,587
17.10.2013, 16:33     Ошибка в аргументе функции #11
Что тут представлять? В функции создали массив на стеке, вышли из функции, память под массивом считается свободной. Если в куче создали, то память занята пока не освободите.
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
17.10.2013, 16:36     Ошибка в аргументе функции
Еще ссылки по теме:

C++ Взятие адреса в аргументе
Значение логарифма при любом аргументе C++
C++ Чем отличаются указатель в теле функции и в аргументе

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

Или воспользуйтесь поиском по форуму:
dzrkot
zzzZZZ...
 Аватар для dzrkot
516 / 346 / 53
Регистрация: 11.09.2013
Сообщений: 1,977
17.10.2013, 16:36     Ошибка в аргументе функции #12
Цитата Сообщение от alsav22 Посмотреть сообщение
Что тут представлять? В функции создали массив на стеке, вышли из функции, память под массивом считается свободной. Если в куче создали, то память занята пока не освободите.
ой... да элементарно не подумал об этом...))
Yandex
Объявления
17.10.2013, 16:36     Ошибка в аргументе функции
Ответ Создать тему
Опции темы

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