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메가가 안된다.)
'C' 카테고리의 다른 글
[C] 수열 합 1-2+3-4+.....+99-100 (정보처리기사 외) (0) | 2019.06.17 |
---|---|
[C] 수열 합1+2+3+...+99+100 (정보처리기사 외) (0) | 2019.06.17 |
[C] 문자열 길이 구하기 (0) | 2019.06.17 |
c언어 scanf 로 문자열 입력받아 출력하기(띄어쓰기도 가능) (0) | 2019.06.17 |
c언어 산 출력하기 (0) | 2019.06.16 |