728x90
반응형
동일한 자료형(Data Type)의 데이터를 연속된 공간에 저장하기 위한 자료구조이다.
즉, 연관된 데이터를 그룹화하여 묶어준다고 생각하면 된다.
💡 배열의 특징
- 동일한 데이터 타입을 순서에 따라 관리하는 자료 구조
- 정해진 크기가 있음
- 요소의 추가와 제거 시 다른 요소들의 이동이 필요함
- 배열의 i번째 요소를 찾는 인덱스 연산이 빠름
- jdk 클래스 : ArrayList, Vector4
Ex >
public class MyArray {
int[] intArr; //int array
int count; //개수
public int ARRAY_SIZE;
public static final int ERROR_NUM = -999999999;
public MyArray()
{
count = 0;
ARRAY_SIZE = 10;
intArr = new int[ARRAY_SIZE];
}
public MyArray(int size)
{
count = 0;
ARRAY_SIZE = size;
intArr = new int[size];
}
public void addElement(int num)
{
if(count >= ARRAY_SIZE){
System.out.println("not enough memory");
return;
}
intArr[count++] = num;
}
public void insertElement(int position, int num)
{
int i;
if(count >= ARRAY_SIZE){ //꽉 찬 경우
System.out.println("not enough memory");
return;
}
if(position < 0 || position > count ){ //index error
System.out.println("insert Error");
return;
}
for( i = count-1; i >= position ; i--){
intArr[i+1] = intArr[i]; // 하나씩 이동
}
intArr[position] = num;
count++;
}
public int removeElement(int position)
{
int ret = ERROR_NUM;
if( isEmpty() ){
System.out.println("There is no element");
return ret;
}
if(position < 0 || position >= count ){ //index error
System.out.println("remove Error");
return ret;
}
ret = intArr[position];
for(int i = position; i<count -1; i++ )
{
intArr[i] = intArr[i+1];
}
count--;
return ret;
}
public int getSize()
{
return count;
}
public boolean isEmpty()
{
if(count == 0){
return true;
}
else return false;
}
public int getElement(int position)
{
if(position < 0 || position > count-1){
System.out.println("검색 위치 오류. 현재 리스트의 개수는 " + count +"개 입니다.");
return ERROR_NUM;
}
return intArr[position];
}
public void printAll()
{
if(count == 0){
System.out.println("출력할 내용이 없습니다.");
return;
}
for(int i=0; i<count; i++){
System.out.println(intArr[i]);
}
}
public void removeAll()
{
for(int i=0; i<count; i++){
intArr[i] = 0;
}
count = 0;
}
}
728x90
반응형
'🗂️ 컴퓨터 과학(CS) > 자료구조(data structure)' 카테고리의 다른 글
[자료구조] 제네릭(generic) (0) | 2023.08.28 |
---|---|
[자료구조] 큐(Queue) (0) | 2023.08.28 |
[자료구조] 스택(Stack) (0) | 2023.08.28 |
[자료구조] 연결 리스트 (LinkedList) (0) | 2023.08.28 |
[자료구조] 자료구조에 대하여 (0) | 2023.08.28 |