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

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

Войти
Регистрация
Восстановить пароль
 
MurderKnot
-98 / 0 / 0
Регистрация: 15.10.2013
Сообщений: 32
#1

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

17.10.2013, 14:26. Просмотров 357. Ответов 11
Метки нет (Все метки)

Доброго времени суток. В университете дали такое задание:
Составить программу на основе ветвления, концепция задачи такова:
(Преподаватель очень весёлый человек, так что не удивляйтесь)
Задан двумерный динамический массив, задающий высоты платформ, по которым прыгает "жук".
Количество платформ задано размерами массива.
Он должен добраться к "жучихе" и собрать для неё цветы, количество которых находится по формуле через высоту
(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 как консольный проект С++
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
17.10.2013, 14:26
Здравствуйте! Я подобрал для вас темы с ответами на вопрос Ошибка в аргументе функции (C++):

Программа для вычисления квадратного корня. Ошибка компиляции в аргументе функции - C++
Всем привет, программа для вычисления квадратного корня. Не компилируется из за вызова функции вычисления кв корня. Ругается на аргументы. ...

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

Чем отличаются указатель в теле функции и в аргументе - C++
Здравствуйте. Не могу разобраться чем, в данном случае: bool LexAnalysis(const char* text) { const char *str = text; const char...

Взятие адреса в аргументе - C++
Есть такой код: void STOCK::acquiare(const std::string &amp;co,long n, double pr) { company=co; if (n&lt;0) { ...

Указатель = 0 в аргументе конструктора - C++
Не знал даже как тему назвать. :D Прошу пояснить такой момент, не в первый раз встречаю, но гугл мне не объяснил. Для чего, иногда в...

Значение логарифма при любом аргументе - C++
при значении аргумента больше 1 следует воспользоваться значением ln10. Не могу понять ошибку, программа работает без цикла if, а с ним...

11
MurderKnot
-98 / 0 / 0
Регистрация: 15.10.2013
Сообщений: 32
17.10.2013, 14:28  [ТС] #2
Ошибка в аргументе функции
0
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++){
?
0
dzrkot
zzzZZZ...
519 / 349 / 53
Регистрация: 11.09.2013
Сообщений: 2,004
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)
1
MurderKnot
-98 / 0 / 0
Регистрация: 15.10.2013
Сообщений: 32
17.10.2013, 15:49  [ТС] #5
dzrkot, зачем же делать так? Это долго и запутанно, компилятор это пропускает, мало того у меня есть рабочие программы, основанные на моём принципе. Так что я думаю проблема не в этом.

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

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

Шаблонная функция, выводящая информацию о своем аргументе - C++
Надо написать программу, буду очень благодарен

Вычислить значение разных функций при определенном аргументе - C++
Вычислить значение y в зависимости от выбранной функции ϕ(x), аргумент которой определяется из поставленного условия. Возможные значения...

@ в аргументе метода - C++
подскажите плиз, что означает следующая запись method(..., object @param)? меня интересует именно &quot;собака&quot; в этой записи

Найти значение многочлена при заданном аргументе, производной от многочлена - C++
Ребята всем привет,,,,прошу вас помогите мне,,,,у меня вопрос жизни или смерти!!!!если вы мне не поможите мне конец!!!и так,,,мне нужно...


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

Или воспользуйтесь поиском по форуму:
12
Yandex
Объявления
17.10.2013, 16:36
Ответ Создать тему
Опции темы

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