강의

멘토링

커뮤니티

인프런 커뮤니티 질문&답변

jsh4059님의 프로필 이미지
jsh4059

작성한 질문수

홍정모의 따라하며 배우는 C++

6.19 다중 포인터와 동적 다차원 배열

6.19 다중포인터와 동적 다차원 배열 질문이 있습니다

작성

·

275

1

10: 51분때

int **matrix=new int*[row];

for(int r=0;r<row;++r)

{

matrix[r]=new int [col];

}

for(int r=0;r<row;++r)

for(int c=0;c<col;++c)

matrix[r][c]=s2da[r][c];

//print all elements

for(int r=0;r<row;++r)

{

for(int c=0;c<col;++c)

cout<<matrix[r][c]<<"  ";

cout<<endl;

}

======================================

 int **matrix=new int*[row] 여기서 왜 int*타입의 원소들의 주소는 matrix[r][c]여기서의 열(row)부분으로 가는건가요? 그냥 외우면 되나요? 

답변 1

6

안녕하세요.

- 포인터는 [ ] 연산이 가능합니다. 예를 들어 ptr[1] 은 *(ptr + 1) 과 같은 의미입니다.(배열도 주소가 담겨있는 배열의 이름을 통해서 []로 원소 데이터들에 접근할 수 있는게 이와 같은 원리입니다.) 따라서 이중 포인터인 matrix로도 matrix[r][c] 같은 표현이 가능합니다.

int **matrix=new int*[row];

for(int r=0;r<row;++r)

{

matrix[r]=new int [col];

}

-  여기까지 하고 난 상태에서는

이와 같은 그림이 됩니다.(row는 3, col는 5라고 가정하고 그려 본 그림입니다.) matrix는 int* 타입의 원소들을 담을 수 있는 동적 배열의 포인터이며, 이를 통해 matrix[r] 로 각각 원소(int 포인터)들에  int 데이터들을 담는 col 길이의 배열의 주소를 할당한 모습입니다. 

예를 들어 matrix[0]에는 첫번째 int 배열의 주소가 담깁니다. 그러므로 이제 matrix[0][2] 로 첫번째 int 배열의 세번째 원소 데이터에 접근할 수 있게 됩니다. "포인터는 [ ] 연산이 가능합니다. 예를 들어 ptr[1] 은 *(ptr + 1) 과 같은 의미입니다" 라고 처음에 언급 드린 것을 잘 생각해주시면 이해가 되실거에요!

jsh4059님의 프로필 이미지
jsh4059

작성한 질문수

질문하기