C
C언어로 단위행렬 만들기
데브웅
2019. 6. 16. 23:20
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
|
#include <stdio.h>
int main()
{
int size;
scanf("%d", &size);
int **Identity = malloc(sizeof(int *) * size);
int i, j;
for (i=0; i < size; i++)
{
Identity[i] = malloc(sizeof(int) * size);
memset(Identity[i], 0, sizeof(int) * size);
}
for (i=0; i<size; i++)
Identity[i][i] = 1;
for (i=0; i<size; i++)
{
for (j=0; j<size; j++)
{
printf("%d ", Identity[i][j]);
}
printf("\n");
}
for (i=0; i<size; i++)
{
free(Identity[i]);
}
free(Identity);
return 0;
}
|
cs |
2차원 배열은 이중포인터를 이용해서 heap 공간에 메모리를 할당받아야 한다.
그냥 2차원 배열을 matrix[i][j] 같이 선언하면, stack 공간에 할당되므로 행렬 할당 용량에 제한이 생긴다.
(윈도우의 stack은 1메가가 안된다.)