반응형

 

배열 인덱스는 왜 0부터 시작하는가 

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

 
 
 


 

반응형

'알고리듬과 수학' 카테고리의 다른 글

속도와 속력  (0) 2018.06.20
소수 구하기 (Prime number)  (0) 2018.06.12
등식과 방정식  (0) 2018.06.04
순열과 조합의 수  (0) 2018.06.01
최대공약수  (0) 2018.06.01

+ Recent posts