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

Передача массива в функцию - C++

Восстановить пароль Регистрация
 
4ance
1 / 1 / 0
Регистрация: 02.11.2010
Сообщений: 78
03.02.2011, 20:07     Передача массива в функцию #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
...
int UnichtojenieFiguryMas( int *EnemyLocationXvalue[ ], int z/* размер обоих массивов */, int *EnemyLocationYvalue[ ], int Ocherednost );
 
int _tmain(int argc, _TCHAR* argv[])
{
int  Enemy;
    int EnemyLocationXvalue[ 16 ];
    int EnemyLocationYvalue[ 16 ];
    int SummaHodov = 0;
...
 
    for ( int i = 0; i < Enemy - 1; i++ )
    {
        SummaHodov = UnichtojenieFiguryMas( &EnemyLocationXvalue[ 0 ], Enemy, &EnemyLocationYvalue[ 0 ], i );
    }
cout << endl;
        cout << SummaHodov;
    _getch();
    return 0;
}
 
int UnichtojenieFiguryMas( int *x, int z/*размер обоих массивов - не использую*/, int *y, int Ocherednost )
{
 
...                      
 
    Doska[ x + Ocherednost ][ y + Ocherednost ] = 0;       // Клетка начала пути
Queue[ 0 ][ 0 ] = x + Ocherednost;        // Заносит в очередь координату Х начальной клетки
    Queue[ 1 ][ 0 ] = y + Ocherednost;        <-------Error
  
...
 
}
Выдаёт: error C2440: '=' : cannot convert from 'int *' to 'int'

В чём проблема?
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
gooseim
Эксперт C++
500 / 404 / 35
Регистрация: 23.09.2010
Сообщений: 1,139
03.02.2011, 23:49     Передача массива в функцию #2
4ance, можно посмотреть описание класса объектов Doska и Queue?
sadok
14 / 14 / 0
Регистрация: 26.01.2011
Сообщений: 64
04.02.2011, 00:39     Передача массива в функцию #3
UnichtojenieFiguryMas - а разве сигнатуры у них лдинаковы(прототип и функция ?),в прототипе указан массив,а принемаеш переменную
4ance
1 / 1 / 0
Регистрация: 02.11.2010
Сообщений: 78
04.02.2011, 13:07  [ТС]     Передача массива в функцию #4
Цитата Сообщение от sadok Посмотреть сообщение
UnichtojenieFiguryMas - а разве сигнатуры у них лдинаковы(прототип и функция ?),в прототипе указан массив,а принемаеш переменную
Насколько я понимаю, компилятор в прототипе функции видит только типы данных int, и указатели - int *, остальное - игнорирует. Прототип сообщает компилятору количество аргументов и их тип, в порядке ожидаемого появления.
Хотя тут я как раз и могу ошибаться, т.к. первый раз сталкиваюсь с передачей массива в функцию.

Добавлено через 12 минут
Цитата Сообщение от gooseim Посмотреть сообщение
4ance, можно посмотреть описание класса объектов Doska и Queue?
Doska - матрица 8х8.
Queue - очередь, структура данных. первое значения - для х и у координат, второе - для меток Start, Last, запоминающих положение коня после его перехода на следующую позицию ( В 8 if'ах смоделированы возможные ходы коня, которые прибавляют очередь Last, после всех возможных ходов с данной клетки прибавляется метка Start. )

Функция с ошибками:
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
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
int UnichtojenieFiguryMas( int *x, int z, int *y, int Ocherednost )
{
    int Doska[ 8 ][ 8 ], i, j, a, b, Start, Last;
    int Queue[ 2 ][ 64 ];
 
    for ( i = 0; i < 8; i++ )
        for ( j = 0; j < 8; j++ )
            Doska[ i ][ j ] = -1;        // Заполняет матрицу значением -1                         
 
    Doska[ x + Ocherednost ][ y + Ocherednost ] = 0;        // Клетка начала пути        <----- Error C2107: illegal index, indirection not allowed
    Queue[ 0 ][ 0 ] = x + Ocherednost;        // Заносит в очередь координату Х начальной клетки              <----- Error C2440: '=' : cannot convert from 'int *' to 'int'
    Queue[ 1 ][ 0 ] = y + Ocherednost;        // Заносит в очередь координату Y начальной клетки              <-----   Error C2440: '=' : cannot convert from 'int *' to 'int'
    Start = 0;                    // Начальная позиция левого указателя
    Last = 1;                    // Начальная позиция правого указателя
 
    // Запускаем цикл, который продолжает работу до тех пор,
    // пока очередь не пуста или искомый конечный элемент не помечен
    while ( ( Start != Last ) && ( Doska[ x + Ocherednost + 1 ][ y + Ocherednost + 1 ] == -1 ) )        <----- Error C2107: illegal index, indirection not allowed, 
                                     Fatal error C1903: unable to recover from previous error(s); stopping compilation
    {
        a = Queue[ 0 ][ Start ];    // Запоминает координату Х текущей клетки
        b = Queue[ 1 ][ Start ];    // Запоминает координату Y текущей клетки
 
        /* Следующие 8 операторов if перебирают все возможные ходы коня,
        предусматривая возможность выхода за пределы поля, и если клетка, в которую можно пойти, 
        не помечена, то ее координаты заносятся в очередь,
        а она сама помечается увеличенной на единицу меткой клетки,
        из которой мы попали в текущую */ 
        //cout << endl;
        if ( ( Doska[ a + 2 ][ b - 1 ] == -1 ) && ( a + 2 < 8 ) && ( b - 1 < 8 ) && ( a + 2 > 0 ) && ( b - 1 > 0 ) )
        {
            Queue[ 0 ][ Last ] = a + 2;
            Queue[ 1 ][ Last ] = b - 1;
            Last++;
            Doska[ a + 2 ][ b - 1 ] = Doska[ a ][ b ] + 1;
        }
        if ( ( Doska[ a + 2 ][ b + 1 ] == -1 ) && ( a + 2 < 8 ) && ( b + 1 < 8 ) && ( a + 2 > 0 ) && ( b + 1 > 0 ) )
        {
            Queue[ 0 ][ Last ] = a + 2;
            Queue[ 1 ][ Last ] = b + 1;
            Last++;
            Doska[ a + 2 ][ b + 1 ] = Doska[ a ][ b ] + 1;
        }
        if ( ( Doska[ a - 2 ][ b + 1 ] == -1 ) && ( a - 2 < 8 ) && ( b + 1 < 8 ) && ( a - 2 > 0 ) && ( b + 1 > 0 ) )
        {
            Queue[ 0 ][ Last ] = a - 2;
            Queue[ 1 ][ Last ] = b + 1;
            Last++;
            Doska[ a - 2 ][ b + 1 ] = Doska[ a ][ b ] + 1;
        }
        if ( ( Doska[ a - 2 ][ b - 1 ] == -1 ) && ( a - 2 < 8 ) && ( b - 1 < 8 ) && ( a - 2 > 0 ) && ( b - 1 > 0 ) )
        {
            Queue[ 0 ][ Last ] = a - 2;
            Queue[ 1 ][ Last ] = b - 1;
            Last++;
            Doska[ a - 2 ][ b - 1 ] = Doska[ a ][ b ] + 1;
        }
        if ( ( Doska[ a - 1 ][ b + 2 ] == -1 ) && ( a - 1 < 8 ) && ( b + 2 < 8 ) && ( a - 1 > 0 ) && ( b + 2 > 0 ) )
        {
            Queue[ 0 ][ Last ] = a - 1;
            Queue[ 1 ][ Last ] = b + 2;
            Last++;
            Doska[ a - 1 ][ b + 2 ] = Doska[ a ][ b ] + 1;
        }
        if ( ( Doska[ a + 1 ][ b + 2 ] == -1 ) && ( a + 1 < 8 ) && ( b + 2 < 8 ) && ( a + 1 > 0 ) && ( b + 2 > 0 ) )
        {
            Queue[ 0 ][ Last ] = a + 1;
            Queue[ 1 ][ Last ] = b + 2;
            Last++;
            Doska[ a + 1 ][ b + 2 ] = Doska[ a ][ b ] + 1;
        }
        if ( ( Doska[ a + 1 ][ b - 2 ] == -1 ) && ( a + 1 < 8 ) && ( b - 2 < 8 ) && ( a + 1 > 0 ) && ( b - 2 > 0 ) )
        {
            Queue[ 0 ][ Last ] = a + 1;
            Queue[ 1 ][ Last ] = b - 2;
            Last++;
            Doska[ a + 1 ][ b - 2 ] = Doska[ a ][ b ] + 1;
        }
        if ( ( Doska[ a - 1 ][ b - 2 ] == -1 ) && ( a - 1 < 8 ) && ( b - 2 < 8 ) && ( a - 1 > 0 ) && ( b - 2 > 0 ) )
        {
            Queue[ 0 ][ Last ] = a - 1;
            Queue[ 1 ][ Last ] = b - 2;
            Last++;
            Doska[ a - 1 ][ b - 2 ] = Doska[ a ][ b ] + 1;
        }
        Start++;    // Удаляет первый элемент из очереди
    }
    cout << Doska[ x + Ocherednost + 1 ][ x + Ocherednost + 1 ];
    return Doska[ x + Ocherednost + 1 ][ x + Ocherednost + 1 ];
}
Добавлено через 8 минут
С первого поста, та ошибка
error C2440: '=' : cannot convert from 'int *' to 'int'
Выпадает для 14й линии -
C++
1
SummaHodov = UnichtojenieFiguryMas( &EnemyLocationXvalue[ 0 ], Enemy, &EnemyLocationYvalue[ 0 ], i );
Добавлено через 2 часа 52 минуты
Всё, исправил все проблемы, пишу дальше
Yandex
Объявления
04.02.2011, 13:07     Передача массива в функцию
Ответ Создать тему
Опции темы

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