6.19 다중포인터와 동적 다차원 배열 질문이 있습니다
283
작성한 질문수 34
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) 과 같은 의미입니다" 라고 처음에 언급 드린 것을 잘 생각해주시면 이해가 되실거에요!
변수가 메모리에 저장되는 것을 알려주는 강의가 어떤강의였죠
1
461
1
메모리 주소 10진수로 출력
1
650
1
클래스 템플릿 특수화에서 boolalpha로 표현된 리턴값에 대해 질문이 있습니다.
1
496
1
여러가지 리턴 타입에 관한 강의가 어떤 걸까요?
1
529
1
메모리 주소에 관한 질분
0
676
1
인터페이스 클래스에서 reportError의 매개변수에 대해 궁금한 것이 있습니다.
0
547
1
형변환 오버로딩에서 const 관련 질문이 있습니다.
0
439
1
Digit 뒤에 reference를 사용하는 이유
0
504
1
4.2 전역 변수, 정적 변수, 내부 연결, 외부 연결
0
319
1
dat파일이...
0
534
1
TODO:대입 연산자 오버로딩에 대한 소스코드입니다.
0
640
1
복사 생성자 관련 질문이 있습니다.
0
450
1
수업 중 궁금한점이 있습니다.
1
386
1
라이브러리자체가 이해가 되지 않습니다.
0
558
1
마지막 예제 질문
0
299
1
증감연산자 위치에 따른 수행 순서 질문입니다.
0
371
1
단항 연산자 오버로딩에서 return 부분에 질문이 있습니다.
1
408
1
friend함수 관련 질문이 있습니다.
0
308
1
operator+ 정의부분에서 궁금한 것이 있습니다.
0
443
1
3분 17초 질문
0
346
1
함수에 값을 대입한다는 개념이 이해가 되지 않습니다.
0
443
1
int getvalue() const에서 const는 왜 뒤에 붙는건가요?
0
440
2
const Something &st에서 const를 빼면 안되나요?
0
296
1
friend함수는 다른 클래스의 멤버함수로 쓸 수 없나요??
1
489
1





