Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.80/5: Рейтинг темы: голосов - 5, средняя оценка - 4.80
1 / 1 / 0
Регистрация: 12.11.2012
Сообщений: 33

Массивы. Статика

11.12.2012, 20:49. Показов 1099. Ответов 15
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
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
#include <iostream>
 
void vvod(int, int, int*);
void sozd(int, int, int *, int*, int*);             
void vivod(int*, int, int&);
using namespace std;
 
void main()
{
    setlocale (LC_ALL, "rus");
    int z = 0 , mz, nz, otv, mx, nx;
    const int mt = 50, nt = 50;
 
    
    cout<<"\n Введите размерность матрицы X : mx и nx соответственно \n ";
    cin>>mx>>nx;
    int masX[mt][nt];
    vvod(mx, nx, masX);
 
    int my, ny;
    cout<<"\n Введите размерность матрицы Y : my и ny соответственно \n ";
    cin>>my>>ny;
    int masY[mt][nt];
    vvod( my, ny, masY);
    
    
}

При компиляции выдает ошибку:
error C2664: vvod: невозможно преобразовать параметр 3 из 'int [50][50]' в 'int *'

Подскажите в чем проблема?

C++
1
2
3
4
5
6
7
8
9
10
11
12
void vvod (int mx, int nx, int* masX)
{
    for(int i=0; i<mx; ++i)
    {
        for( int j=0; j<nx; j++)
        {
            cout<<"\n Введите элемент "<<i+1<<"x"<<j+1<<"  ";
            cin>>masX[i][j];
        }
    }
 
}
И тут при компиляции ошибка: error C2109: для индекса требуется массив или указатель
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
11.12.2012, 20:49
Ответы с готовыми решениями:

Динамика и статика (массивы)
1)Почему при статическом выделении памяти массив обязательно объявлять в функции main? 2)Почему его нельзя вернуть через return из...

Массив - статика/динамика
Дан массив n целых чисел а1...аn. Пусть m и М— наименьшее и наибольшее из них. Если разность этих чисел по модулю меньше, чем число,...

Статика
Доброго времени суток. Помогите пожалуйста разобраться в статике. Читаю метанит. Когда дошёл до статики возникло несколько вопросов...

15
Пес войны
 Аватар для NeonLost
111 / 88 / 22
Регистрация: 23.02.2012
Сообщений: 653
11.12.2012, 20:52
звездочку убери в функции
1
1 / 1 / 0
Регистрация: 12.11.2012
Сообщений: 33
11.12.2012, 20:59  [ТС]
Цитата Сообщение от NeonLost Посмотреть сообщение
звездочку убери в функции
Какую? Где именно?
0
Пес войны
 Аватар для NeonLost
111 / 88 / 22
Регистрация: 23.02.2012
Сообщений: 653
11.12.2012, 21:11
Цитата Сообщение от Tapelkam Посмотреть сообщение
Какую? Где именно?
C++
1
void vvod (int mx, int nx, int* masX)
здесь
1
1 / 1 / 0
Регистрация: 12.11.2012
Сообщений: 33
11.12.2012, 21:18  [ТС]
все равно такая же проблема
0
Пес войны
 Аватар для NeonLost
111 / 88 / 22
Регистрация: 23.02.2012
Сообщений: 653
11.12.2012, 21:31
упсик
C++
1
2
3
vvod(mx, nx, &masX[0][0]);
 
void vvod (int mx, int nx, int *masX)
Добавлено через 5 минут
или так
C++
1
2
3
void vvod (int mx, int nx, int masX[][50])
 
vvod(mx, nx, masX);
0
1 / 1 / 0
Регистрация: 12.11.2012
Сообщений: 33
11.12.2012, 21:54  [ТС]
С вводом решилась проблема. Спасибо. А вот в main все равно остались ошибки
0
Пес войны
 Аватар для NeonLost
111 / 88 / 22
Регистрация: 23.02.2012
Сообщений: 653
11.12.2012, 22:35
Цитата Сообщение от Tapelkam Посмотреть сообщение
С вводом решилась проблема. Спасибо. А вот в main все равно остались ошибки
покажи как исправил(
1
1 / 1 / 0
Регистрация: 12.11.2012
Сообщений: 33
11.12.2012, 23:06  [ТС]
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
#include <iostream>
#include <conio.h>
#include <math.h>
 
void vvod(int, int, int);
void sozd(int, int, int *, int*, int*);             
void vivod(int*, int, int&);
using namespace std;
 
void main()
{
    setlocale (LC_ALL, "rus");
    int z = 0 , mz, nz, otv, mx, nx;
    const int mt = 50, nt = 50;
 
    do{
    cout<<"\n Введите размерность матрицы X : mx и nx соответственно \n ";
    cin>>mx>>nx;
    int masX[mt][nt];
    vvod(mx, nx, masX[][50]);
 
    int my, ny;
    cout<<"\n Введите размерность матрицы Y : my и ny соответственно \n ";
    cin>>my>>ny;
    int masY[mt][nt];
    vvod( my, ny, masY[][50]);
    
    if( (mx == my && nx==ny)&&(mx==nx && ny==my) )
    {
        mz=mx, nz=nx;
        int masZ[mt][nt];
        int *ppp = *masZ;
        sozd(mz, nz, masX[][50], masY[][50], masZ);
        vivod(masZ, mx, otv);
    }
    else {cout<<"\n Матрица не была построена"
        <<"\n Повторить решение? 1/0 \t";
    cin>>otv;}
 
    }while(otv==1);
    _getch();
}

C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
#include <iostream>                                                                                         
using namespace std;
 
void vvod (int mx, int nx, int masX[][50])
{
    for(int i=0; i<mx; ++i)
    {
        for( int j=0; j<nx; j++)
        {
            cout<<"\n Введите элемент "<<i+1<<"x"<<j+1<<"  ";
            cin>>masX[i][j];
        }
    }
 
}
0
Пес войны
 Аватар для NeonLost
111 / 88 / 22
Регистрация: 23.02.2012
Сообщений: 653
11.12.2012, 23:44
Цитата Сообщение от Tapelkam Посмотреть сообщение
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
#include <iostream>
#include <conio.h>
#include <math.h>
 
void vvod(int, int, int);
void sozd(int, int, int *, int*, int*);             
void vivod(int*, int, int&);
using namespace std;
 
void main()
{
    setlocale (LC_ALL, "rus");
    int z = 0 , mz, nz, otv, mx, nx;
    const int mt = 50, nt = 50;
 
    do{
    cout<<"\n Введите размерность матрицы X : mx и nx соответственно \n ";
    cin>>mx>>nx;
    int masX[mt][nt];
    vvod(mx, nx, masX[][50]);
 
    int my, ny;
    cout<<"\n Введите размерность матрицы Y : my и ny соответственно \n ";
    cin>>my>>ny;
    int masY[mt][nt];
    vvod( my, ny, masY[][50]);
    
    if( (mx == my && nx==ny)&&(mx==nx && ny==my) )
    {
        mz=mx, nz=nx;
        int masZ[mt][nt];
        int *ppp = *masZ;
        sozd(mz, nz, masX[][50], masY[][50], masZ);
        vivod(masZ, mx, otv);
    }
    else {cout<<"\n Матрица не была построена"
        <<"\n Повторить решение? 1/0 \t";
    cin>>otv;}
 
    }while(otv==1);
    _getch();
}

C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
#include <iostream>                                                                                         
using namespace std;
 
void vvod (int mx, int nx, int masX[][50])
{
    for(int i=0; i<mx; ++i)
    {
        for( int j=0; j<nx; j++)
        {
            cout<<"\n Введите элемент "<<i+1<<"x"<<j+1<<"  ";
            cin>>masX[i][j];
        }
    }
 
}
ну епт, перечитай мое сообщение, я вызов функции не менял(функцию оставь, а вызов верни как было у тебя сначала)
1
1 / 1 / 0
Регистрация: 12.11.2012
Сообщений: 33
12.12.2012, 07:58  [ТС]
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
#include <iostream>                                                                                         
using namespace std;
 
void vvod (int mx, int nx, int masX[][50])
{
    for(int i=0; i<mx; ++i)
    {
        for( int j=0; j<nx; j++)
        {
            cout<<"\n Введите элемент "<<i+1<<"x"<<j+1<<"  ";
            cin>>masX[i][j];
        }
    }
 
}
 
 
void vivod (int masZ[][50], int mx, int& otv)
{
    cout<<"\n";
    for(int i=0; i<mx; ++i)
    {
        cout<<"\n";
        for( int j=0; j<mx; j++)
        {
            cout<<*(*(masZ+i)+j)<<"  ";
        }
            
    }
    cout<<"\n Повторить решение? 1/0 \t";
    cin>>otv;
    
}


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
#include <iostream>
#include <conio.h>
 
void vvod(int, int, int[][50]);
void sozd(int, int, int [][50], int[][50], int[][50]);              
void vivod(int[][50], int, int&);
using namespace std;
 
void main()
{
    setlocale (LC_ALL, "rus");
    int z = 0 , mz, nz, otv, mx, nx;
    const int mt = 50, nt = 50;
 
    do{
    cout<<"\n Введите размерность матрицы X : mx и nx соответственно \n ";
    cin>>mx>>nx;
    int masX[mt][nt];
    vvod(mx, nx, masX);
 
    int my, ny;
    cout<<"\n Введите размерность матрицы Y : my и ny соответственно \n ";
    cin>>my>>ny;
    int masY[mt][nt];
    vvod( my, ny, masY);
    
    if( (mx == my && nx==ny)&&(mx==nx && ny==my) )
    {
        mz=mx, nz=nx;
        int masZ[mt][nt];
        sozd(mz, nz, masX, masY, masZ);
        vivod(masZ, mx, otv);
    }
    else {cout<<"\n Матрица не была построена"
        <<"\n Повторить решение? 1/0 \t";
    cin>>otv;}
 
    }while(otv==1);
    _getch();
}
Сделал вот так. Поставил во всех функциях. Вроде бы работает. Правильно все?
0
Форумчанин
Эксперт CЭксперт С++
 Аватар для MrGluck
8216 / 5047 / 1437
Регистрация: 29.11.2010
Сообщений: 13,453
12.12.2012, 08:01
Tapelkam, правильно - это использовать динамические массивы и писать int main.
0
Пес войны
 Аватар для NeonLost
111 / 88 / 22
Регистрация: 23.02.2012
Сообщений: 653
12.12.2012, 19:40
Цитата Сообщение от MrGluck Посмотреть сообщение
Tapelkam, правильно - это использовать динамические массивы и писать int main.
не везде их правильно использовать
0
CEO SOVAZ Corp.
 Аватар для sovaz1997
386 / 232 / 51
Регистрация: 17.12.2011
Сообщений: 822
Записей в блоге: 1
12.12.2012, 19:46
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
#include <iostream>
 
void vvod(int, int, int*);
void sozd(int, int, int *, int*, int*);
//void vivod(int*, int, int&);
using namespace std;
 
int main()
{
    setlocale (LC_ALL, "rus");
    int z = 0 , mz, nz, otv, mx, nx;
    const int mt = 50, nt = 50;
 
 
    cout<<"\n Введите размерность матрицы X : mx и nx соответственно \n ";
    cin>>mx>>nx;
    int masX[mt][nt];
    vvod(mx, nx, *masX);
 
    int my, ny;
    cout<<"\n Введите размерность матрицы Y : my и ny соответственно \n ";
    cin>>my>>ny;
    int masY[mt][nt];
    vvod( my, ny, *masY);
 
 
}
 
void vvod(int a, int b, int* c) {
 
}
0
1 / 1 / 0
Регистрация: 12.11.2012
Сообщений: 33
12.12.2012, 20:15  [ТС]
Цитата Сообщение от MrGluck Посмотреть сообщение
правильно - это использовать динамические массивы и писать int main.
Мне нужно на статике. Динамику я сделал)
0
Пес войны
 Аватар для NeonLost
111 / 88 / 22
Регистрация: 23.02.2012
Сообщений: 653
12.12.2012, 23:41
Цитата Сообщение от sovaz1997 Посмотреть сообщение
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
#include <iostream>
 
void vvod(int, int, int*);
void sozd(int, int, int *, int*, int*);
//void vivod(int*, int, int&);
using namespace std;
 
int main()
{
    setlocale (LC_ALL, "rus");
    int z = 0 , mz, nz, otv, mx, nx;
    const int mt = 50, nt = 50;
 
 
    cout<<"\n Введите размерность матрицы X : mx и nx соответственно \n ";
    cin>>mx>>nx;
    int masX[mt][nt];
    vvod(mx, nx, *masX);
 
    int my, ny;
    cout<<"\n Введите размерность матрицы Y : my и ny соответственно \n ";
    cin>>my>>ny;
    int masY[mt][nt];
    vvod( my, ny, *masY);
 
 
}
 
void vvod(int a, int b, int* c) {
 
}
и сразу пропадает понятный код(так не получится)
C++
1
2
3
4
5
6
7
8
void vvod(int a, int b, int* c) 
{
    for(int i=0; i<10; i++)
    {
        for(int j=0; j<10; j++)
        cin>>c[i][j];
    }
}
если только так

C++
1
2
3
4
5
6
7
8
void vvod(int a, int b, int* c) 
{
    for(int i=0; i<10; i++)
    {
        for(int j=0; j<10; j++)
        cin>>*(c+i*j+10);
    }
}
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
12.12.2012, 23:41
Помогаю со студенческими работами здесь

Статика
Люди понимающие, объясните мне принципы убийства статическим электричеством. Заодно покритикуйте мою версию, как это понимаю я. Моя...

Статика
Читаю про статические функции, там пример такой: &lt;?php class test{ const POW = 2; static $sumlength = 0; static...

Динамика vs. статика
Существует динамический сайт который в Last-Modified всегда отдает текущее время, реальные изменения с течением времение незначительные -...

Статика резервом
на serial у меня резерв на статике с повышенной метрикой, отключаю интерфейсы которые на fiber на них пробит ospf, проверяю из всех офисов...

Не обновляется статика
Доброго времени суток! Прошу помочь разобраться вот с какой проблемой. В какой-то момент работы над проектом перестал работать механизм...


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

Или воспользуйтесь поиском по форуму:
16
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Обработчик клика мыши в браузере ПК и касания экрана в браузере на мобильном устройстве
8Observer8 02.02.2026
Содержание блога Для начала пошагово создадим рабочий пример для подготовки к экспериментам в браузере ПК и в браузере мобильного устройства. Потом напишем обработчик клика мыши и обработчик. . .
Философия технологии
iceja 01.02.2026
На мой взгляд у человека в технических проектах остается роль генерального директора. Все остальное нейронки делают уже лучше человека. Они не могут нести предпринимательские риски, не могут. . .
SDL3 для Web (WebAssembly): Вывод текста со шрифтом TTF с помощью SDL3_ttf
8Observer8 01.02.2026
Содержание блога В этой пошаговой инструкции создадим с нуля веб-приложение, которое выводит текст в окне браузера. Запустим на Android на локальном сервере. Загрузим Release на бесплатный. . .
SDL3 для Web (WebAssembly): Сборка C/C++ проекта из консоли
8Observer8 30.01.2026
Содержание блога Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
SDL3 для Web (WebAssembly): Установка Emscripten SDK (emsdk) и CMake для сборки C и C++ приложений в Wasm
8Observer8 30.01.2026
Содержание блога Для того чтобы скачать Emscripten SDK (emsdk) необходимо сначало скачать и уставить Git: Install for Windows. Следуйте стандартной процедуре установки Git через установщик. . . .
SDL3 для Android: Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 29.01.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами. Версия v3 была полностью переписана на Си, в. . .
Инструменты COM: Сохранение данный из VARIANT в файл и загрузка из файла в VARIANT
bedvit 28.01.2026
Сохранение базовых типов COM и массивов (одномерных или двухмерных) любой вложенности (деревья) в файл, с возможностью выбора алгоритмов сжатия и шифрования. Часть библиотеки BedvitCOM Использованы. . .
SDL3 для Android: Загрузка PNG с альфа-каналом с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 28.01.2026
Содержание блога SDL3 имеет собственные средства для загрузки и отображения PNG-файлов с альфа-каналом и базовой работы с ними. В этой инструкции используется функция SDL_LoadPNG(), которая. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru