다차원 배열과 포인터에 관한 질문입니다.
터전
#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)맞는 수식이 아닙니다..
번호 | 제 목 | 글쓴이 | 날짜 |
---|---|---|---|
2690486 | 문자열과 문자형이요 ~ | 다스리 | 2025-04-05 |
2690344 | 일본어 주석 깨짐 문제 (3) | 연하얀 | 2025-04-04 |
2690314 | 암호문 만들기 -비제네르- | 이퓨리한나 | 2025-04-03 |
2690292 | 왕초보자의 질문!!!!!! 도와주세요 (1) | 하랑 | 2025-04-03 |
2690269 | 정올 문제 인데.. 흠 | 반월 | 2025-04-03 |
2690237 | sizeof에서 short형을 썻는데 왜 4byte가 나올까요? (1) | 바나나 | 2025-04-03 |
2690183 | 문자열과 포인트 비교 (2) | 미즈 | 2025-04-02 |
2690154 | a -48 ? | 희미한눈물 | 2025-04-02 |
2690094 | 테트리스 질문요. | 지후 | 2025-04-01 |
2690066 | 문자열비교!! (1) | 매디 | 2025-04-01 |
2689888 | 좀도와주세요;; ㅠㅠ | 사람 | 2025-03-30 |
2689856 | 메뉴 그리는 거 질문 | 나라빛 | 2025-03-30 |
2689831 | c언어 프로그램 추천 | 하연 | 2025-03-30 |
2689801 | c언어 time.h에서 작동이 중지되었습니다. | 하람 | 2025-03-30 |
2689772 | 2차원 배열의 배열명에 대해서.. | 옆집꼬마야 | 2025-03-29 |
2689740 | 게임 TCP소켓 질문 (2) | 불꾼 | 2025-03-29 |
2689711 | 반복문 모래시계 | 한뎃집 | 2025-03-29 |
2689685 | 경우의 수에 따른 결과 처리 질문드립니다. (2) | 다흰 | 2025-03-29 |
2689655 | .exe에 아이콘 넣는 법좀 알려주세요 | 연하얀 | 2025-03-28 |
2689631 | #define 전처리문에 대해서 (2) | 사랑은아픔 | 2025-03-28 |