반응형
배열 인덱스는 왜 0부터 시작하는가
글. 오상문 sualchi@daum.net
다음처럼 1차원 배열이 선언되었을 때,
int a[10];
a 배열의 첫 번째 항목은 a[0]입니다.
얼핏 생각하면 첫 번째 항목이니 a[1]이 맞을 것 같지만 a[1]은 두 번째 항목입니다.
얼핏 생각하면 첫 번째 항목이니 a[1]이 맞을 것 같지만 a[1]은 두 번째 항목입니다.
참고로, 배열 괄호 안에 위치를 가리키는 값을 인덱스(index)라고 부릅니다.
이제 배열 인덱스가 0부터 시작하는 이유를 살펴보겠습니다.
배열 이름은 그 배열이 저장된 메모리 시작 위치를 가리킵니다.
그러므로 1차원 배열에서 a가 가리키는 주소는 첫 번째 항목 위치와 같습니다.
O O O O O O O O O O
주소
|
a
배열 이름은 그 배열이 저장된 메모리 시작 위치를 가리킵니다.
그러므로 1차원 배열에서 a가 가리키는 주소는 첫 번째 항목 위치와 같습니다.
O O O O O O O O O O
주소
|
a
배열 각 항목은 시작 위치를 기준으로 몇 칸 떨어진 곳에 있다는 식으로 접근합니다.
a[0]은 a를 기준으로 0칸 떨어진 위치의 값을 다룹니다. 즉, 첫 번째 항목입니다.
a[1]은 a를 기준으로 1칸 떨어진 위치의 값을 다룹니다. 즉, 두 번째 항목입니다.
...
a[9]는 a를 기준으로 9칸 떨어진 위치가 값을 다룹니다. 즉, 열 번째 항목입니다.
a[1]은 a를 기준으로 1칸 떨어진 위치의 값을 다룹니다. 즉, 두 번째 항목입니다.
...
a[9]는 a를 기준으로 9칸 떨어진 위치가 값을 다룹니다. 즉, 열 번째 항목입니다.
O O O O O O O O O O
| |
a [0] ... a[9]
| |
a [0] ... a[9]
참고로, a[10]은 열한 번째 항목인데 a 배열에 선언된 크기를 넘어가므로 에러가 발생합니다.
항목 10개
O O O O O O O O O O
| | ???
a [0] ... a[9] a[10]
인덱스 범위 에러
O O O O O O O O O O
| | ???
a [0] ... a[9] a[10]
인덱스 범위 에러
이제 배열 인덱스가 왜 0부터 시작해야하는지 아시겠죠? ^^
<이상>
반응형