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

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

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Помогите НАПИСАТЬ ПРАГУ на языке Visual Studio 2010 (c++) http://www.cyberforum.ru/cpp-beginners/thread237852.html
НУЖНО создать масив строк,он представяет двумерный масив char, заполнить ето-т масив с клавиатуры, отсортировать строки по алфавиту, найти строки с минимальной и максимальной длинны, обьеденить все строки в одну ... ЗАРАНИЕ СПС !!!парни оч надо выручыте=(т
C++ простейшее серверное приложение здравствуйте. Мне необходимо запрограммировать простейшее серверное приложение, к которому можно подключиться через tellnet и получать от этого серверного приложения эхо в виде вводимых команд в консоль tellnet. Посоветуйте где про разработку таких приложений подробно разъясняется, язык начал изучать недавно.. http://www.cyberforum.ru/cpp-beginners/thread237837.html
C++ Чтение и запись в файл чисел
Как правильно записывать и читать числа в файлах? Все сделал как в книге, открываб в блокноте, символы. При чтение не читает вообще. FILE *fp; int n=101; if ((fp=fopen("test.txt","w"))==NULL) { printf("Cannot open file .\n"); exit(1); }; //n=fread(&n,sizeof(int),1,fp);
C++ Перегрузка оператора ~
Доброго времени суток! Помогите пожалуйста с решением задачи. Описать класс множество целых чисел. Перегрузить следующую операцию: ~ объединение множеств. (т.е. mnozh3=mnozh1~mnozh2 означает, что множество mnozh3 состоит из элементов множеств mnozh1 и mnozh2). Под множеством понимается одномерный массив не содержащий повторяющихся элементов. Например, - множество, - не является...
C++ Есть идеи? http://www.cyberforum.ru/cpp-beginners/thread237801.html
Шеф-повар столовой решила устроить День Уважения к Повару. Для этого она приготовила N необычайно вкусных котлет и втайне постановила, что первый пожаловавший отведать поварское кушанье должен получить наибольшее количество вкусных котлет, а каждый последующий — строго меньше, чем предыдущий (повару очень не нравилось, когда к приготовленному обеду опаздывали и горячее остывало). Конечно,...
C++ Почему не работает strlen()??? Код программы: #include<string> #include<iostream> using namespace std; int main(){ string s; getline(cin, s, '\n'); int d=0; d=strlen(s); подробнее

Показать сообщение отдельно
4ance
1 / 1 / 0
Регистрация: 02.11.2010
Сообщений: 78
04.02.2011, 13:07  [ТС]     Передача массива в функцию
Цитата Сообщение от 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 минуты
Всё, исправил все проблемы, пишу дальше
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru