다차원 배열과 포인터에 관한 질문입니다.
터전
#include stdio.h
int main(void)
{
int arr[2][2][2]={1,2,3,4,5,6,7,8};
printf(arr[1][0][1] : %d \n,arr[1][0][1]);
return 0;
}
이렇게 참조하면 값이 6이 나오는데
(*(arr+1))[0][1] 이렇게 인덱스에 접근해도 6이 나오잖아여.. 궁금한건 arr[1] 이거를 *(arr+1) 이렇게 표현도 할수 있는건 알겠는데 왜 한번더 ()를 붙이는거에여?
그냥 *(arr+1)[0][1] 이렇게 하면 7이 나오거든여...()를 왜 한번 더 넣어주는지 잘 모르겠네여 제 생각으로는 안 넣어도 똑같은 문장인거 같은데 ㅡㅡ;
이질문을 검색해보니까 답변이 이렇게 달려있었는데요.. 잘 이해가 안되네요 ㅜㅜㅜㅜ 왜()한번더 붙여야되는지
인덱스 연산자는 +한만큼 주소를 건너뛰게 되는데요 (*(arr+1))[0][1] 는 arr이 연속적인 배열이라고 보았을 경우 (arr[8]로 말입니다,) *(arr+4+0+1)이 되어서 6이 나오게 되구요
*(arr+1)[0][1]의 경우에는 *(arr+0+2+4)의 경우가 되어 7이 나오게 됩니다.
예를 들어 드리면 arr[3][2][2] = {1.....12}로 하신뒤 *(arr+1)[1][0]과 (*arr+2))[0][0]의 값이 같게 나오는것을 보실수 있어요
*보다 +가 우선순위가 높죠 ()가 없다면 (*arr)+1[0][1]과 같은 말이 되기 때문입니다
(*(arr+1))[0][1]=*(arr+4+0+1) // *(arr+1)[0][1]=*(arr+0+4) 이부분좀 설명해주실분~
-
아더 2024-12-22
즐프하시구 행복하세요.. :)
-
물보라 2024-12-22
아아~수다님 감사해요~이제좀 이해가되네요
-
하예진 2024-12-22
우선은 연산자 우선 순위 때문에 그렇죠...
*(pointer+i) == pointer[i] 라고 생각하시면 됩니다.. 이게 왜 똑같냐고 물으시면..
1 + 2 == 3 이게 왜 같냐고 물어볼겁니다.. (약속이기 때문이죠..)
(*(arr+1))[0][1] 의 경우 다른 배열 인덱스 보다 *가 먼저 연산되므로 .. arr[1][0][1]
*(arr+1)[0][1] 의 경우 *보다 배열인덱스가 우선순위가 높기 때문에..
arr+1을 X라 가정하면.. -
상큼한캔디 2024-12-22
(*(arr+1))[0][1]=*(arr+4+0+1) // *(arr+1)[0][1]=*(arr+0+4) 이부분좀 설명해주실분~
메모리 구조상은 맞는 말이긴 한데.. 그러려면 arr이 아닌 다른 포인터 변수를 사용해야 할 듯..
arr을 사용하시면 (*(arr+1))[0][1]=*(arr+4+0+1)맞는 수식이 아닙니다..