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

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

Войти
Регистрация
Восстановить пароль
 
4ance
1 / 1 / 0
Регистрация: 02.11.2010
Сообщений: 78
#1

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

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

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
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
03.02.2011, 20:07
Здравствуйте! Я подобрал для вас темы с ответами на вопрос Передача массива в функцию (C++):

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

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

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

передача массива в функцию - C++
у меня в мейне есть двумерный массив нужно его передать в дургую функцию как это сделать подскажите плиз

Передача массива в функцию - C++
Почему мусор выводит? bool insert(int* mas, int n, int v) { int _n = n + 1; int* mas2 = new int; for (int i = 0; i &lt; n; ++i) ...

Передача массива в функцию - C++
есть массив a 100 - кол-во точек 0,1,2 - координаты соответственно x,y,z нужно написать функцию которая будет находить расстояние между...

3
gooseim
Эксперт С++
508 / 412 / 37
Регистрация: 23.09.2010
Сообщений: 1,159
03.02.2011, 23:49 #2
4ance, можно посмотреть описание класса объектов Doska и Queue?
0
sadok
14 / 14 / 0
Регистрация: 26.01.2011
Сообщений: 64
04.02.2011, 00:39 #3
UnichtojenieFiguryMas - а разве сигнатуры у них лдинаковы(прототип и функция ?),в прототипе указан массив,а принемаеш переменную
0
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 минуты
Всё, исправил все проблемы, пишу дальше
0
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
04.02.2011, 13:07
Привет! Вот еще темы с ответами:

Передача массива в функцию - C++
Как сделать функцию, в которую будет передавться массив. я что-то не оч понимаю. вот исходный код #include &lt;iostream&gt; #include...

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

Передача массива в функцию С++ - C++
Например у меня есть функция для создания массива. И есть функция, которая дальше работает с уже созданным массивом. Как мне этот созданный...

Передача массива в функцию - C++
Добрый день! Начал изучать C++ и столкнулся вот с какой проблемой. Я передаю массив в некоторую функцию. В конечном итоге передаваемый...


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

Или воспользуйтесь поиском по форуму:
4
Yandex
Объявления
04.02.2011, 13:07
Ответ Создать тему
Опции темы

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