Форум программистов, компьютерный форум, киберфорум
C для начинающих
Войти
Регистрация
Восстановить пароль
Другие темы раздела
C (СИ) Подправьте код где надо. Динамическое распределение памяти в языке С, Символьные данные и строки https://www.cyberforum.ru/ c-beginners/ thread797699.html
Подправьте код под Visual Studio 2010 на Си Задание 1. В программе определите и инициализируйте переменную X типа double, указатель double * и указатель типа void *. Присвойте указателям адрес...
C (СИ) Последняя группа совершенных чисел
Создать двоичный файл и записать в него n целых чисел. Последнюю группу совершенных чисел из исходного файла переписать в текстовый файл. Помогите пожалуйста, первую часть задания могу сделать, а...
Проверка вводимой информации C (СИ)
Добрый день. При вводе в программе номера группы студента(Тип данных - структура) необходимо проверить правильность ввода. *** ... printf(Rus("\nНомер группы:\n\n")); ...
C (СИ) Строки Дана строка. Найти число вхождений в ее подстроку , расположенную левее первого символа «.», подстроки из двух символов «:=». Если символ «.» является самым первым символом исходной строки, либо... https://www.cyberforum.ru/ c-beginners/ thread797613.html
C (СИ) Сформировать матрицу по заданному образцу https://www.cyberforum.ru/ c-beginners/ thread797608.html
Сформировать матрицу по заданному образцу не могу фотку вставить((( но как то так):swoon: l 1 l 1 l 1 l ...l 1 l l 2 l 2 l 2 l ...l 2 l l...l ...l ...l ...l...l l n l n l n l ...l n l
Побитовая обработка: в каждом байте переместить все единичные биты в конец C (СИ)
В каждом байте переместить все единичные биты в конец (Без использования строк и массивов). Есть программа для подсчета единичных битов, но не знаю как их переместить. #include <stdio.h> #include...
C (СИ) Мистика с функциями
Всем привет форумчане! У меня на пути познания C возникла одна мистическая проблема, вот: по отдельности эти две функции работают отлично void symbols() { int i = 0, c; while((c = getchar()) !=...
C (СИ) Вычислить и вывести на экран таблицу всех 20 значений функции делаю лабороторную "цилкы" Вычислить и вывести на экран таблицу всех 20 значений функции z(i,j)=xi2+yi3; для xi=x1, x2, x3, x4; yi = y1, y2,…, y5 Исходные данные: x1 = 0.1, x2 = 0.2, x3 = 0.3, x4... https://www.cyberforum.ru/ c-beginners/ thread797553.html
C (СИ) Найти произведение, сумму и количество отрицательных элементов массива https://www.cyberforum.ru/ c-beginners/ thread797552.html
Привет)) Заполнить матрицу m*n с клавиатуры. Найти произведение,сумму и количество отрицательных элементов массива. Спасибо:*
C (СИ) Вывести на печать исходный массив и предпоследний столбец массива Заполнить случайными числами матрицу n*m. Вывести на печать исходный массив и предпоследний столбец массива. Спасибо! https://www.cyberforum.ru/ c-beginners/ thread797534.html
...
1793 / 1260 / 932
Регистрация: 12.02.2013
Сообщений: 2,058
01.03.2013, 06:46 0

Выделение памяти под динамический массив

01.03.2013, 06:46. Просмотров 1043. Ответов 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
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
91
#include <stdio.h> //scanf, printf
#include <stdlib.h>
#include <conio.h> //getch
 
int EnterN();
void matrix_assign(int, int**);
void matrix_diplay(int, int**);
int matrix_check(int, int**);
 
int main()
{
   int n, i, max, **matrix;
   //n-размерность, i и j для счётчиков, max для хранения макс. элемента
   n = EnterN();
   matrix = (int**) malloc(n * sizeof(int*));
   for (i = 0; i < n; ++i)
   {
      matrix[i] = (int*) malloc(n * sizeof(int));
   }
 
   matrix_assign(n, matrix);
   matrix_diplay(n, matrix);
   max = matrix_check(n, matrix);
   //Вывод максимального элемента.
   printf("\nMAX element of this matrix is %d", max);
   getch();
 
   return 0;
}
 
//Ввод N для определения размерности матрицы
int EnterN()
{
   int n;
   do
   {
      printf("BBEDUTE N\n N=");
      scanf("%d", &n);
   }
   while (n >= 12);
   return (n);
}
 
//ввод элементов матрицы
void matrix_assign(int n, int** matrix)
{
   int i, j;
   for (i = 0; i < n; i++)
      for (j = 0; j < n; j++)
      {
         printf("BBEDUTE matrix[%d][%d]\n", i, j);
         scanf("%d", &matrix[i][j]);
      }
 
}
 
//Вывод матрицы на экран.
void matrix_diplay(int n, int** matrix)
{
   int i, j;
   for (i = 0; i < n; i++)
   {
      for (j = 0; j < n; j++)
      {
         printf("[%2.1i] ", matrix[i][j]);
      }
      printf("\n");
   }
   getch();
}
 
//Проверка первой половины матрицы. Сверху вниз.
int matrix_check(int n, int** matrix)
{
   int max = 0, i, j;
   for (i = 0; i < (int)(n / 2); i++)
      for (j = i; j < n - i; j++)
         //Сравнение текущего [i][j] элемента с максимальным
         if (matrix[i][j] > max)
         {
            max = matrix[i][j];
         }
   //Проверка оставшейся части матрицы.
   for (; i < n; i++)
      for (j = n - i - 1; j <= i; j++)
         if (matrix[i][j] > max)
         {
            max = matrix[i][j];
         }
   return (max);
}
Выделение памяти под динамический массив


Исходник + бинарник: program.7z

Вернуться к обсуждению:
Выделение памяти под динамический массив
1
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
01.03.2013, 06:46
Готовые ответы и решения:

Выделение памяти под динамический массив строк
Суть программы такова: при вызове функции количество структур увеличивается на одну, выделяется под...

Выделение памяти под динамический массив выдает ошибку
В общем проблема такова, при компиляции вылазит ошибка: 27 C:\Users\USER\Desktop\projects\main.c...

Выделение памяти под двумерный массив
Здравствуйте! скажите пожалуйста почему нельзя выделить под двумерный массив память через функцию....

Динамическое выделение памяти под массив
Здравствуйте, помогите пожалуйста сделать в процедуре input динамическое выделение памяти под...

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