2차원배열이 함수에 들어왔을때
375
작성한 질문수 22
#include <stdio.h>
#define ROWS 3
#define COLS 4
int sum2d_3(int* arr, int rows, int cols);
int main()
{
int data[ROWS][COLS] = { {1,2,3,4},{5,6,7,8},{9,0,1,2} };
return 0;
}
int sum2d_3(int *arr, int rows, int cols)
{
int r, c, tot = 0;
for (r = 0; r < rows; r++)
for (c = 0; c < cols; c++)
tot += *(arr + c + cols * r);
return tot;
}여기서 data는 포인터 연산시 자료형이 int(*)[4] 주소자료형입니다.
2차원 배열 data를 함수의 안에 넣고 매개변수 int *arr로 사용할때 tot += *(arr + c + cols * r); 를 보면 마치 배열 arr가 1차원 배열인것처럼 사용되고 있습니다.
Q.2차원 배열은 함수안에 들어가면 1차원배열처럼 포인터 연산이 되는건가요?
감사합니다.
답변 1
2
안녕하세요, 답변 도우미 Soobak 입니다.
질문 ) 2차원 배열은 함수안에 들어가면 1차원 배열처럼 포인터 연산이 되는건가요?
: 2차원 배열이 함수에 전달될 때 자동으로 1차원 배열로 변하는 것은 아닙니다.
다만, 함수의 프로토 타입을 살펴보면, int sum2d_3(int* arr, int rows, int cols) 으로 int* 자료형의 포인터가 매개변수로 선언되어있습니다.
따라서, int* arr 로 선언되어있는 매개변수에 2차원 배열 data 를 인수로써 전달하면, data 는 첫 번째 행의 첫 번째 요소, 즉, &data[0][0] 을 가리키는 포인터로 해석되어 함수에 전달됩니다.
만약, 매개변수의 자료형을 int arr[ROWS][COLS] 또는 int arr[][COLS] 로 변경하신다면, arr[r][c] 와 같은 인덱스 참조로 원소에 접근할 수 있습니다.
또한, 강의 10.5 2차원 배열과 메모리 을 참고해보시면,C언어에서 메모리는 1차원으로 구성되어있으며, 메모리 상에서 2차원 배열 또한 연속적으로 나열되어 저장됩니다.
따라서, 위와 같은 포인터 연산을 통하여 2차원 배열의 요소에 접근할 수 있는 것입니다.
Export template 안됨
1
19
2
완전히 똑같이 따라해도 exe파일이 안만들어져서 실행이 안됩니다.
1
54
3
main 함수에서 왜 int만 선언이 되는걸까요
1
56
2
8비트 2진수 변환시 왜 1을 더해야하나요?
1
54
2
혹시 강의를 빠르게 수강하려면 어디서부터 듣는게 좋을까요?
1
49
1
프로토타입과 함수간의 인자 불일치
1
73
2
12.12 헤더 관련 질문
1
60
2
Visual Studio Community 2026 사용 문의
1
138
2
Q. 15:30, 부호가 있는 8비트 정수 질문
1
61
2
getchar(), putchar()
1
93
3
강의자리ㅛ
1
80
2
비주얼스튜디오코드로 공부해도 상관없나요?
1
114
2
소스파일안에 여러 파일
1
76
2
F5와 F7의 차이
1
77
2
c = TWO * (a+b); 에서 a와 b는?
1
58
2
; 세미콜론을 붙이는 기준에 문의
1
70
1
Step over 기능 문의
1
53
2
2.6 강의 따옴표 출력 규칙 문의
1
75
2
int main 함수 관련 오류 문의
1
67
2
13.4 words[0]
0
61
2
11.7 함수를 구현해 봤습니다.
1
62
2
11.6 직접 strcmp와 strncmp를 구현해 보았습니다.
1
65
2
11.6 my_strcat과 my_strncat을 구현해봤습니다.
1
53
2
11.6 fit_str함수를 구현해 봤습니다.
1
53
2





