Форум программистов, компьютерный форум, киберфорум
C для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.93/15: Рейтинг темы: голосов - 15, средняя оценка - 4.93
6 / 7 / 4
Регистрация: 17.09.2013
Сообщений: 337

Динамическое выделение памяти для матрицы

21.01.2014, 17:39. Показов 2927. Ответов 4
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Программа выглядит так.
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
#include <stdio.h>
#include <conio.h>
typedef int *pInt;
int main() {
    int N, M, i, j;
    pInt *A;
    scanf("%d %d", &N, &M);
    A = new pInt[M];
    for(i = 0; i < M; i++) {
          A[i] = new int[N];
          }
          for(i = 0; i < M; i++) {
                for(j = 0; j < N; j++) {
                scanf("%d", A[i][j]);
                }
                }
                for(i = 0; i < N; i++) {
                      for(j = 0; j < M; j++) {
                            printf("%d ", A[i][j]);
                            }
                            printf("\n");
                            }
                            for(i = 0; i < M; i++) {
                                  delete A[i];
                                  }
                                  delete A;
                                  getch();
                                  return 0;
                                  }
Я не могу ввести вторую строку, программа принудительно закрывается. Помогите найти ошибку.
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
21.01.2014, 17:39
Ответы с готовыми решениями:

Динамическое выделение памяти для массива
Есть лаба, задание скриншотом ниже. Я вроде бы как сделал его, но вот второй массив который я использую что бы не терять данные с...

Динамическое выделение памяти для массива
Допустим следующее: Имеется массив типа структуры struct stct buf1 Далее массив по ходу выполнения программы заполняется необходимой...

Динамическое выделение памяти для двумерного массива
Здравствуйте! В следующей программе я пытаюсь выделить динамически память для двумерного массива. Размерности массива задаются в...

4
...
 Аватар для anmartex
1910 / 1329 / 966
Регистрация: 12.02.2013
Сообщений: 2,172
21.01.2014, 17:47
new и delete это из языка C++.

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
#include <stdio.h>
#include <stdlib.h>
 
int main() {
    unsigned N, M, i, j;
    int** A;
    scanf("%u %u", &N, &M);
 
    A = malloc(sizeof(int*) * M);
    for (i = 0; i < M; i++) {
        A[i] = malloc(sizeof(int) * N);
    }
 
    for (i = 0; i < M; i++) {
        for (j = 0; j < N; j++) {
            scanf("%d", &A[i][j]);
        }
    }
 
    for (i = 0; i < M; i++) {
        for (j = 0; j < N; j++) {
            printf("%d ", A[i][j]);
        }
        printf("\n");
    }
 
    for (i = 0; i < M; i++) {
        free(A[i]);
    }
    free(A);
 
    system("pause");
 
    return 0;
}
0
6 / 7 / 4
Регистрация: 17.09.2013
Сообщений: 337
21.01.2014, 18:04  [ТС]
Цитата Сообщение от anmartex Посмотреть сообщение
new и delete это из языка C++.

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
#include <stdio.h>
#include <stdlib.h>
 
int main() {
    unsigned N, M, i, j;
    int** A;
    scanf("%u %u", &N, &M);
 
    A = malloc(sizeof(int*) * M);
    for (i = 0; i < M; i++) {
        A[i] = malloc(sizeof(int) * N);
    }
 
    for (i = 0; i < M; i++) {
        for (j = 0; j < N; j++) {
            scanf("%d", &A[i][j]);
        }
    }
 
    for (i = 0; i < M; i++) {
        for (j = 0; j < N; j++) {
            printf("%d ", A[i][j]);
        }
        printf("\n");
    }
 
    for (i = 0; i < M; i++) {
        free(A[i]);
    }
    free(A);
 
    system("pause");
 
    return 0;
}
В строке
C
1
A = malloc(sizeof(int*) * M);
программа в DevC++ отказывается компиллироваться.
Изначальный код я брал из книги, которую скачал здесь.
http://kpolyakov.narod.ru/school/c.htm
Книга вторая, стр. 50.
0
...
 Аватар для anmartex
1910 / 1329 / 966
Регистрация: 12.02.2013
Сообщений: 2,172
21.01.2014, 18:49
MahovIV, давайте файлу расширение не *.cpp, а *.c. Если вы всё же желаете использовать C++ компилятор, то необходимо выполнить приведение типов.
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
#include <stdio.h>
#include <stdlib.h>
 
int main() {
    unsigned N, M, i, j;
    int** A;
    scanf("%u %u", &N, &M);
 
    A = (int**) malloc(sizeof(int*) * M);
    for (i = 0; i < M; i++) {
        A[i] = (int*) malloc(sizeof(int) * N);
    }
 
    for (i = 0; i < M; i++) {
        for (j = 0; j < N; j++) {
            scanf("%d", &A[i][j]);
        }
    }
 
    for (i = 0; i < M; i++) {
        for (j = 0; j < N; j++) {
            printf("%d ", A[i][j]);
        }
        printf("\n");
    }
 
    for (i = 0; i < M; i++) {
        free(A[i]);
    }
    free(A);
 
    system("pause");
 
    return 0;
}
Добавлено через 4 минуты
Страница 47 вашего учебника, "Динамическое выделение памяти":
... Прием, о котором мы будем говорить, относится уже не к стандартному языку Си,
а к его расширению Си ++ ...
0
6 / 7 / 4
Регистрация: 17.09.2013
Сообщений: 337
22.01.2014, 01:29  [ТС]
Цитата Сообщение от anmartex Посмотреть сообщение
MahovIV, давайте файлу расширение не *.cpp, а *.c. Если вы всё же желаете использовать C++ компилятор, то необходимо выполнить приведение типов.
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
#include <stdio.h>
#include <stdlib.h>
 
int main() {
    unsigned N, M, i, j;
    int** A;
    scanf("%u %u", &N, &M);
 
    A = (int**) malloc(sizeof(int*) * M);
    for (i = 0; i < M; i++) {
        A[i] = (int*) malloc(sizeof(int) * N);
    }
 
    for (i = 0; i < M; i++) {
        for (j = 0; j < N; j++) {
            scanf("%d", &A[i][j]);
        }
    }
 
    for (i = 0; i < M; i++) {
        for (j = 0; j < N; j++) {
            printf("%d ", A[i][j]);
        }
        printf("\n");
    }
 
    for (i = 0; i < M; i++) {
        free(A[i]);
    }
    free(A);
 
    system("pause");
 
    return 0;
}
Добавлено через 4 минуты
Страница 47 вашего учебника, "Динамическое выделение памяти":
А как выглядит вариант C++?
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
22.01.2014, 01:29
Помогаю со студенческими работами здесь

Динамическое выделение памяти
int *a = (int*)malloc(n * sizeof(int)); int *a // это тип указателя (int* ) // зачем вот это нужно? malloc // возращает...

Динамическое выделение памяти
Приветствую. Имеется код: #include &lt;stdio.h&gt; #include &lt;stdlib.h&gt; typedef struct{ int age; char* name; }...

Динамическое выделение памяти
Необходимо выделить память с помощью функции melloc под 5 символов char. При вводе пользователем строки, в случае если выделенное место...

Динамическое выделение памяти
Всем привет! Недавно начал изучать Си, и возник такой вопрос (кажется, дурацкий, но все же): почему при работе, скажем, со структурами ...

Динамическое выделение памяти в С
Ввести num - количество массивов. Ввести размерность очередного массива и его элементы целого типа, разместить их в динамической памяти....


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

Или воспользуйтесь поиском по форуму:
5
Ответ Создать тему
Новые блоги и статьи
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
Создание Single Page Application на фреймах
krapotkin 16.11.2025
Статья исключительно для начинающих. Подходы оригинальностью не блещут. В век Веб все очень привыкли к дизайну Single-Page-Application . Быстренько разберем подход "на фреймах". Мы делаем одну. . .
Фото: Daniel Greenwood
kumehtar 13.11.2025
Расскажи мне о Мире, бродяга
kumehtar 12.11.2025
— Расскажи мне о Мире, бродяга, Ты же видел моря и метели. Как сменялись короны и стяги, Как эпохи стрелою летели. - Этот мир — это крылья и горы, Снег и пламя, любовь и тревоги, И бескрайние. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru