array, search, insert, delete

2023. 4. 7. 14:20·다양한 글들/자료구조와 알고리즘
Reference :
- 건국대학교 컴퓨터공학과 자료구조 수업 / 김성렬 교수님
Search, Insert, Delete
  • 자료구조의 가장 중요한 연산들
    • 책상 위를 보시오! (우리가 평소에도 많이 하는 작업들 공책에 쓰고 지우고...)
  • 그렇다고 모든 자료 구조에 해당하는 것은 아니다.
    • 예) 그래프
  • Item: 저장되는 대상을 부를 이름
    • 정수만 가능한 것으로 생각을 하자.

임의의 배열을 통해서 알아보자.

 

Array

임의의 배열 형태

임의의 배열의 형태를 생각해보자 배열은 index와 value로 구성되어있다.

그렇다면 위 배열을 토대로 배열 안에서 삽입, 삭제, 검색이 어떻게 이루어지는지 알아보자

 

How to Store Items in an Array?

  • Packed vs Unpacked (빈자리가 있냐? 없냐?)
    • 배열이 항상 가득 차 있는 것은 아니다.
    • 빈 자리를 한 쪽으로 모은다?
  • Sorted vs Unsorted
    • item들이 정렬된 상태를 유지하느냐 아니냐?

총 4가지 경우에 대해서 성능이 어떤지를 알아보는 시간을 가져보겠다.

 

Case 1 ) Packed, Unsorted

  • 가장 간단한 방법
  • Item의 개수를 표시하는 변수가 따로 필요 하다.
  • => 위 배열을 보면 item이 5개 있으니 어딘가에 5라고 저장 해놓으면 해결된다.
  • Search : n개의 배열에서 어떤 값 x가 있는지 없는지 확인, O(n)
  • Insert :  [Search, O(n)], O(1)(상수시간)
  • Delete : [Search, O(n)], O(1)
  • *** Insert와 Delete는 보통 Search를 먼저 수행함

이 경우에는 별로 좋지는 않다. Search가 수행되어야 하는데 Search가 느린편이기 때문이다.

 

Case 2 ) Packed, Sorted

  • Binary Search!
  • Item의 개수를 표시하는 변수가 따로 필요 하다.

  • Search : O(log n) (Binary Search 이용)
  • Insert :  옆으로 하나씩 복사한다음 덮여씌우는 방식을 사용, [Search,O(log n)], O(n)
  • Delete : [Search, O(n)], O(n)
  • *** Insert와 Delete는 보통 Search를 먼저 수행함

아까보다 Search는 좋지만 Insert와 Delete에서는 그렇게 좋지 않음을 알 수 있다. 다만 Search만 주로 이용하는 곳에서는 유용하게 쓰일 수 있을 것이다. (ex) 전자사전 같은 검색위주의 서비스

Case 3 ) UnPacked, UnSorted

  • 빈 자리들이 흩어져 있음

  • Item 별로 사용중인지 아닌지 표시가 필요하다.
  • Mark는 따로 배열을 만들던가 클래스 구조체를 이용해서 표현하는 식으로 생각하면 된다.
  • Search : O(n) (단 ,앞서 봤던 packed, Unsorted 보다는 조금 안좋을수도 있다. unpacked 이기 때문에 한쪽으로 모으는작업 필요)
  • Insert : [Search: O(n)], O(n) (빈자리를 찾아야 하기 때문에 )
  • Delete : [Search: O(n)], O(1)( 안 쓴다고 마킹만 하면 되기 때문에)

그런데 이 경우에는 Insert에서 어떠한 기술 하나를 활용할수 있다.

Free List Head 라는 변수를 하나 만든다. 5라는 뜻은 index 5번이 빈자리라는 뜻이다. 그러면 Free List Head에 모든 빈자리를 적으면 해결이 될까? 그렇지는 않다 빈자리는 시시각각 변하기 때문에 또 Free List Head에서 Insert Delete Search 작업을 해야하기 때문이다. 대신에 이렇게 활용한다. 다음 그림을 보자 

우리는 5의 값이 비어있다는 것을 알고 있다. 그러면 그곳에다가 7을 적는다. 7은 index 7을 뜻하며 그곳이 비어 있다고 약속을 하자.

위와 비슷하게 7에는 2를 적어둔다. 역시 index 2를 가리키며, 그곳이 비어있다고 약속한다.

그러면 2에는 무슨 값을 넣어야하나? -1을 넣는다. -1은 index가 될수 없는 값이며 이는 끝났다는 것을 의미한다.

 

자 이제 Insert를 생각해보자. 어떤값 20을 넣는다고 할때 우리는 5번이 비어있음을 알수 있다. 5번에다가 20을 넣으면 된다.  그런데 20을 넣으면 이제 더이상 빈자리가 아니게 되어서 마크 값도 O로 변경 되어 있을 것이다.

그리고 Free List Head에 값도 변경해줄 필요가 있다. 5의 다음을 가리키는 7로 변경하면 insert가 성공적으로 수행된다.

성공한 배열은 다음과 같은 것이다.

20을 insert 한 배열의 최종 상황

그러면 결과적으로 Insert: [seacrh O(n)] + O(n) (기술추가) -> [seacrh O(n)] + O(1) 로 바뀌게 된다.

이 기술은 Linked List 라고 불리는 기술로 다른 자료구조이다. 추후에 좀더 자세히 다룰것이다.

 

d이 기술의 대표적인 사용법은 우리가 알고 있는 파일 시스템, Free Block List on File System 에서 사용하고 있다. 

 

Case 4 ) UnPacked, Sorted

  • Binary Search!!! ... ... ??????????????

마지막 경우를 살펴보자 이 경우 우리는 Binary Search를 사용할 수 있는가? 빈자리가 있는데 중간을 잘라서 Binary Search를 사용할 수 있나? 이 경우에 하나의 기술을 이용한다. ? 표시는 우리가 이해를 편하기 위해 놓은 거지만 실제로는 어떠한 값이 들어가 있을것이다.  그렇다면 Mark을 무시하고 전체를 Sorting 하는 것이다. 지워진 값들까지 sorting이 되어 있도록 하면 Binary Search를 할수 있다. 예를들어 11을 찾는데 값을 찾았더니 marking 이 X 상태이면 그 값은 없는 값이라고 나타내면 된다.

 

  • Search : O(n) -> 기술 추가 -> O(log n)
  • Insert : [Search, O(log n)], O(n)(최악의 경우, 대부분은 이것보다는 2~3배 정도 나을 것)
  • Delete : [Search O(log n)] , O(1)

 

이것으로 배열에 Insert Search Delete에 대해 알아 보았다. 이러한 자료구조는 많이 쓰이지만 성능이 중요한 곳에서는 조금 힘들것이다. 다음시간에는 좀 더 어려운 자료구조에 대해 배워보겠다.

저작자표시

'다양한 글들 > 자료구조와 알고리즘' 카테고리의 다른 글

Array (배열)  (0) 2023.04.09
자료구조 강의 내용  (0) 2023.04.08
10. 정렬 알고리즘의 비교  (0) 2023.04.01
9. 기 수 정렬  (0) 2023.04.01
8. 힙 정렬  (0) 2023.04.01
'다양한 글들/자료구조와 알고리즘' 카테고리의 다른 글
  • Array (배열)
  • 자료구조 강의 내용
  • 10. 정렬 알고리즘의 비교
  • 9. 기 수 정렬
smile blog
smile blog
건국대 첨단바이오공학부 & 컴퓨터공학부 BT & IT 기술로 희망을 꿈 꿉니당
  • smile blog
    스마일 블로그
    smile blog
  • 전체
    오늘
    어제
    • 분류 전체보기 (816) N
      • 일상 생각들 (2)
      • 학과에 대해 (4) N
        • 첨단바이오공학부 (4) N
        • 컴퓨터공학부 (0)
      • -------- 프로젝트 -------- (0)
      • [DS] 토이 프로젝트 (1)
      • [Web, Game, XR] 토이 프로젝트 (11)
      • 경진대회 (1)
      • -------- 진로 -------- (0)
      • 생물정보학자 (18)
        • 데이터 과학이란? (0)
        • 되는 방법 (8)
        • 책 추천 (2)
        • 인강 (1)
        • 대학 (2)
        • 회사 (1)
        • 학원 (2)
        • 학회 (2)
      • 디지털 헬스케어 (72)
        • 방법 (8)
        • 생각들 (10)
        • 공부법 (4)
        • 책 추천 (2)
        • 학원 (2)
        • 참고 (2)
        • 대학 (3)
        • 회사 (3)
        • 인강 (2)
        • 게임 엔진들 (1)
        • 게임 프로그래머 개론 (2)
        • 게임 프로그래머 취업 전략 가이드 (7)
        • 취업 서류 (1)
        • 애정하는 게임들 (4)
        • XR 테크니컬 아티스트 (9)
        • 영화, 애니메이션 테크니컬 디렉터 (12)
      • -------- 기초 학문 -------- (0)
      • 생명과학 이야기 (2)
        • 대학 강의 (2)
      • 화학 이야기 (0)
      • 컴퓨터과학 이야기 (0)
      • 통계학 이야기 (0)
      • 수학 이야기 (1)
        • 공학 수학 (1)
      • 영어 이야기 (1)
      • 심리학 이야기 (7)
        • 현대인과 정신건강 (7)
      • -------- 컴퓨터 언어 -------- (0)
      • Python (3)
        • 나도코딩의 파이썬 입문 (1)
        • 파이썬 관련 정보 (1)
      • SQL (0)
      • C 언어 (32)
        • 혼자 공부하는 C언어 요약 (1)
        • [책 정리] 혼자 공부하는 C언어 (31)
      • C++ (33)
        • 명품 C++ 프로그래밍 요약 (1)
        • [책 정리] 명품 C++ 프로그래밍 (27)
        • C++ STL (0)
        • 뇌를 자극하는 C++ STL (5)
      • -------- 생명과학 -------- (0)
      • 생화학 (5)
        • 대학 강의 (5)
      • 분자세포생물학 (3)
        • 대학 강의 (3)
      • 유전자치료공학 (2)
        • 대학 강의 (2)
      • 생명정보학 (5)
        • 대학 강의 (5)
      • 약리학 (2)
        • 대학 강의 (2)
      • -------- 컴퓨터과학 -------- (0)
      • 자료구조와 알고리즘 (8)
        • 자료구조와 알고리즘의 정의 (3)
        • [책 정리] C언어로 쉽게 풀어쓴 자료구조 요약 (1)
        • [인강] 자료구조와 알고리즘 (2)
        • 코딩 테스트 대비하기! (1)
      • 컴퓨터 회로 (0)
      • 컴퓨터 구조 (43)
        • 컴퓨터 구조와 운영체제 요약 (1)
        • ---------------------------------------- (0)
        • [전공 책 정리] 컴퓨터 구조 및 설계 (1)
        • Ch1. 컴퓨터 추상화 및 관련 기술 (8)
        • Ch2. 명령어 : 컴퓨터 언어 (11)
        • Ch3. 컴퓨터 연산 (8)
        • Ch4. 프로세서 (11)
        • Ch5. 메모리 계층구조 (3)
        • Ch6. 병렬 프로세서 : 클라이언트에서 클라우드까지 (0)
      • 시스템 프로그래밍 (15)
        • [책 정리] 시스템 프로그래밍 유닉스 & 리눅스 (0)
        • [인강] 리눅스 시스템 프로그래밍 (2)
        • 리눅스에서 코딩이란? (8)
        • 대학교 강의 정리 (5)
      • 운영체제 (0)
      • 컴퓨터 네트워크 (37)
        • 모두의 네트워크 요약 (1)
        • [책 정리] 모두의 네트워크 (10)
        • ---------------------------------------- (0)
        • [전공 책 정리] 컴퓨터 네트워킹 하향식 접근 8판 (1)
        • Ch1. 컴퓨터 네트워크와 인터넷 (7)
        • Ch2. 애플리케이션 계층 (7)
        • Ch3. 트랜스포트 계층 (8)
        • Ch4. 네트워크 계층 : 데이터 평면 (3)
        • Ch5. 네트워크 계층 : 제어 평면 (0)
        • Ch6. 링크 계층과 근거리 네트워크 (0)
        • Ch7. 무선 및 이동 네트워크 (0)
        • Ch8. 컴퓨터 네트워크 보안 (0)
      • 데이터베이스 (1)
      • -------- 데이터과학 -------- (0)
      • 데이터 사이언스 (8)
        • 인강 (8)
      • 데이터 분석 (2)
        • 인강 (2)
      • 머신러닝 (2)
        • 대학 수업 (2)
      • 인공지능 (11)
        • 대학교 강의 정리 (10)
        • 인공지능 관련 정보 (1)
      • -------- +a -------- (0)
      • Visual Studio Community (7)
        • 설치법 (1)
        • 단축키 (1)
        • 오류 (5)
      • Visual Studio Code (0)
      • 노션 (1)
      • 깃허브 (7)
        • 깃허브 사용법 (5)
        • 유니티, 언리얼 & 깃허브 (1)
        • 깃허브 주의사항 (1)
      • 챗GPT 활용법 (0)
      • 기타 feat. 프로그래밍 (7)
        • 프로그래머로 살아남기 (5)
        • 코딩 vs 프로그래밍 (1)
        • 애플 비전 프로 (1)
      • 메타버스 (5)
      • -------- 예술 -------- (0)
      • 음악 (1)
      • 미술 (0)
      • -------- XR -------- (0)
      • 유니티 이야기 (23)
        • 레트로의 유니티 게임 프로그래밍 에센스 요약 (4)
        • 유니티 관련 정보 (1)
        • 유니티 디버깅 (13)
        • 유니티 인강 (3)
        • 대학교 게임 프로그래밍 강의 (2)
      • 언리얼 이야기 (0)
        • 인생 언리얼 교과서 요약 (0)
      • 컴퓨터 그래픽스 (6)
        • OpenGL (6)
      • 가상현실 & 증강현실 (4)
        • 유니티 vr (4)
      • HCI 와 UI UX (7)
        • [책 정리] HCI 개론 (6)
      • -------- Design -------- (0)
      • 캐릭터 (1)
        • 모델링 (0)
        • 리깅 (1)
      • 포토샵 (3)
      • 3ds Max (7)
      • Maya (9)
        • 블로그 (1)
        • 인강 (6)
        • 대학교 (2)
      • Blender (14)
        • 책 (1)
        • 인강 (7)
        • 기타 (3)
        • 대학교 (3)
      • 아트 작업물들 (2)
      • 에셋 사이트 (1)
      • -------- 건강관리 -------- (0)
      • 건강관리 ft. 정현 (12)
        • 목 디스크 (2)
        • 눈 관리 (2)
        • 일상생활 습관 (6)
        • 일상생활 꿀팁 (2)
        • 사무직 꿀팁 (0)
      • 헬스의 정석 ft. 정현 (28)
        • 헬스와 건강 (8)
        • 헬스 구체화 정보 (6)
        • 헬스 유튜버 (1)
        • 헬스 서적 (1)
        • 도전 바디프로필! (11)
        • 헬스장 패션 (1)
      • -------- etc -------- (0)
      • 진로 관련 잡다한 글들 (34)
        • 진도율 (9)
        • 진로 관련 글들 (15)
        • 학교 강의 관련 글들 (10)
      • 인생 꿀 Tip (23)
        • 컴퓨터 초기 설정 (9)
        • 원격 데스크톱 (1)
        • 노트북 발열 (1)
        • 전자기기 (2)
        • 중고기기 팔기 (1)
        • 아이패드 필기 어플 (1)
        • 에어팟 (1)
        • 커피 (1)
        • 맥북 (1)
        • lg 그램 (1)
        • 검색엔진에서 내 티스토리 검색 (1)
        • hELLO 다크 모드 없애기 (1)
        • 인터넷 연결 문제 (1)
        • 키보드 문제 해결 (1)
      • 유튜브 (3)
      • 청춘 그리고 추억 (1)
      • 인생 계획표 (2)
        • 2024년 2학기 (1)
        • 2024년 여름방학 (0)
        • 2024년 1학기 (0)
        • 2023년 겨울방학 (1)
      • 다양한 글들 (98)
        • C++ STL (6)
        • Win32 API (24)
        • PushPush 게임 (13)
        • 컴퓨터구조 (1)
        • 자료구조와 알고리즘 (50)
        • 게임의 정의 (3)
        • 영상 회사 (1)
  • 블로그 메뉴

    • 홈
    • 태그
    • 방명록
  • 링크

  • 공지사항

    • Dream
    • 코딩을 시작한 이유
    • 나를 소개합니다!
    • 블로그 공부법
    • IT & 가치 있는 일들
  • 인기 글

  • 태그

    인공지능
    블렌더
    컴퓨터구조
    리눅스
    데이터과학
    데이터사이언스
    C언어
    코드잇
    AI
    유니티
    C++
    생물정보학
    알고리즘
    건국대
    리눅스 터미널
    자료구조
    생명공학
    명령어
    의생명공학과
    스택
    함수
    의생명공학
    포인터
    심리학
    C++ STL
    unity
    컴퓨터 네트워크
    배열
    첨단바이오공학부
    연산자
  • 최근 댓글

  • hELLO· Designed By정상우.v4.10.3
smile blog
array, search, insert, delete
상단으로

티스토리툴바