Python Data Structure (3) - Set

에이블·2022년 2월 4일
0

파이썬

목록 보기
6/20

본 게시물은 코드프레소의 code.PRESS-UP 체험단 과정을 담은 게시물입니다.

해당 게시물 수강강좌 :

금융 데이터 분석을 위한 파이썬 프로그래밍

금융 데이터 분석을 위한 파이썬 프로그래밍 시작하기

https://www.codepresso.kr/course/51

Set

이번 코드프레소 강의를 통해 알아볼 데이터 구조는 집합(Set)입니다.

집합 자료형은 학교 수학시간에 들었던 말 그래도 집합입니다.

  • 집합(set)은 파이썬 2.3부터 지원하기 시작한 자료형
  • 집합에 관련된 것을 쉽게 처리하기 위해 만든 자료형

코드프레소 강의를 통해 한번 알아보도록 합시다.

표현법

다음과 같이 set 키워드를 사용해 만들 수 있다.

>>> s1 = set([1,2,3])
>>> s1
{1, 2, 3}

위와 같이 set()의 괄호 안에 리스트를 입력하여 만들거나 다음과 같이 문자열을 입력하여 만들 수도 있다.

>>> s2 = set("Hello")
>>> s2
{'e', 'H', 'l', 'o'}

특징

집합 자료형은 크게 두가지 특징이 있다.

  • 중복을 허용하지 않는다.
  • 순서가 없다.

리스트나 튜플은 순서가 있기 때문에(Ordered)
인덱싱을 통해 요소들을 활용할 수 있지만

집합은 순서가 없기 때문에(Unodered) 인덱싱으로 요소를 활용할 수 없다.

만약 집합에 저장된 요소들을 인덱싱으로 접근하려면 다음과 같이 리스트나 튜플로 변환해야 한다.

>>> s1 = set([1,2,3])
>>> l1 = list(s1)
>>> l1
[1, 2, 3]
>>> l1[0]
1
>>> t1 = tuple(s1)
>>> t1
(1, 2, 3)
>>> t1[0]
1

연산

set 자료형을 정말 유용하게 사용하는 경우는 교집합, 합집합, 차집합을 구할 때이다.

우선 다음과 같이 2개의 set 자료형을 만든 후 따라 해 보자. s1은 1부터 6까지의 값을 가지게 되었고, s2는 4부터 9까지의 값을 가지게 되었다.

교집합

"&" 기호를 이용하면 교집합을 간단히 구할 수 있다.

>>> s1 & s2
{4, 5, 6}

또는 다음과 같이 intersection 함수를 사용해도 동일한 결과를 돌려준다.

>>> s1.intersection(s2)
{4, 5, 6}

합집합

합집합은 다음과 같이 구할 수 있다. 이때 4, 5, 6처럼 중복해서 포함된 값은 한 개씩만 표현된다.

"|" 기호를 사용한 방법이다.

>>> s1 | s2
{1, 2, 3, 4, 5, 6, 7, 8, 9}

또는 union 함수를 사용하면 된다. 교집합에서 사용한 intersection 함수와 마찬가지로 s2.union(s1)을 사용해도 동일한 결과를 돌려준다.

>>> s1.union(s2)
{1, 2, 3, 4, 5, 6, 7, 8, 9}

차집합

빼기(-) 기호를 사용한 방법이다.

>>> s1 - s2
{1, 2, 3}
>>> s2 - s1
{8, 9, 7}

difference 함수를 사용해도 차집합을 구할 수 있다.

>>> s1.difference(s2)
{1, 2, 3}
>>> s2.difference(s1)
{8, 9, 7}

메소드

add(x)

이미 만들어진 set 자료형에 값을 추가할 수 있다. 1개의 값만 추가(add)할 경우에는 다음과 같이 한다.

>>> s1 = set([1, 2, 3])
>>> s1.add(4)
>>> s1
{1, 2, 3, 4}

update(x, y, z, ...)

여러 개의 값을 한꺼번에 추가(update)할 때는 다음과 같이 하면 된다.

>>> s1 = set([1, 2, 3])
>>> s1.update([4, 5, 6])
>>> s1
{1, 2, 3, 4, 5, 6}

remove(x)

특정 값을 제거하고 싶을 때는 다음과 같이 하면 된다.

>>> s1 = set([1, 2, 3])
>>> s1.remove(2)
>>> s1
{1, 3}

이상으로 코드프레소 강의와 함께 알아본 집합 자료형입니다.

다음 강의는 딕셔너리 자료형이네요.

이 역시 좋은 강의일거라 생각됩니다.

profile
꺾이지 않는 마음

0개의 댓글