Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Карта форума Темы раздела Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.86/7: Рейтинг темы: голосов - 7, средняя оценка - 4.86
2 / 2 / 1
Регистрация: 02.11.2010
Сообщений: 78
1

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

03.02.2011, 20:07. Показов 1293. Ответов 3
Метки нет (Все метки)

Author24 — интернет-сервис помощи студентам
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'

В чём проблема?
0
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
03.02.2011, 20:07
Ответы с готовыми решениями:

Передача массива в функцию используя указатель на функцию
У меня имеется готовая программа без передачи функции в функцию указателем, мне нужно передать...

Передача двухмерного массива из функцию в функцию
Допустим у меня есть функция, в которой &quot;генерируется&quot; массив. Но нужно его передать в другую...

Передача двухмерного массива в функцию и изменение элемента массива
Такая проблема! Нужно передать в функцию двухмерный массив и изменить на елемент который равен 0 и...

Передача массива структур в функцию не указывая размера массива
Я читаю с командной строки файл в котором содержится массив структур. Есть библиотека с функцией в...

3
Эксперт С++
516 / 421 / 92
Регистрация: 23.09.2010
Сообщений: 1,165
03.02.2011, 23:49 2
4ance, можно посмотреть описание класса объектов Doska и Queue?
0
14 / 14 / 1
Регистрация: 26.01.2011
Сообщений: 64
04.02.2011, 00:39 3
UnichtojenieFiguryMas - а разве сигнатуры у них лдинаковы(прототип и функция ?),в прототипе указан массив,а принемаеш переменную
0
2 / 2 / 1
Регистрация: 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 минуты
Всё, исправил все проблемы, пишу дальше
0
04.02.2011, 13:07
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
04.02.2011, 13:07
Помогаю со студенческими работами здесь

С\С++ Передача в функцию 2 массива
Всем доброго времени суток, при написание программы столкнулся с проблемой. void qs(int s_arr,...

Передача массива в функцию
Как записать данные в массив, который в функции и после вызова функции получить эти данные. По...

Передача массива в функцию
Доброе время суток! Товарищи профессионалы! Помогите, очень прошу! как передать в функцию массив...

Передача массива в функцию
Помогите передать массив в функцию #include &lt;iostream&gt; using namespace std; void...


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

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2024, CyberForum.ru