본문 바로가기

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
#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], 0sizeof(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메가가 안된다.)