-
chapter02-6 집합 자료형점프 투 파이썬 2021. 9. 7. 17:20
집합 자료형은 다음과 같이 set 키워드를 사용해 만들 수 있다.
In [1]:s1=set([1,2,3]) s1
Out[1]:{1, 2, 3}
위와 같이 set()의 괄호 안에 리스트를 입력하여 만들거나 다음과 같이 문자열을 입력하여 만들 수도 있다.
In [2]:s2=set("Hello") s2
Out[2]:{'H', 'e', 'l', 'o'}
집합 자료형의 특징¶
자, 그런데 위에서 살펴본 set("Hello")의 결과가 좀 이상하지 않은가? 분명"Hello" 문자열로 set자료형을 만들었는데 생성된 자료형에는 l문자가 하나 빠져 있고 순서도 뒤죽박죽이다. 그이유는 set에 다음과 같은 2가지 큰 특징이 있기 때문이다.
- 중복을 허용하지 않는다.
- 순서가 없다.
리스트나 튜플은 순서가 있기 때문에 인덱싱을 통해 자료형의 값을 얻을 수 있지만 set 자료형은 순서가 없기 때문에 인덱싱으로 값을 얻을 수 없다. 이는 마치 02-5에서 살펴본 딕셔너리와 비슷하다. 딕셔너리 역시 순서가 없는 자료형이라 인덱싱을 지원하지 않는다. 만약 set 자료형에 저장된 값을 인덱싱으로 접근하려면 다음과 같이 리스트나 튜플로 변환한 후 해야한다.
In [3]:s1=set([1,2,3]) l1=list(s1) l1
Out[3]:[1, 2, 3]
In [4]:l1[0]
Out[4]:1
In [9]:t1=tuple(s1) t1
Out[9]:(1, 2, 3)
In [10]:t1[0]
Out[10]:1
교집합, 합집합, 차집합 구하기¶
set 자료형을 정말 유용하게 사용하는 경우는 교집합, 합집합, 차집합을 구할 때이다.
우선 다음과 같이 2개의 set자료형을 만든 후 따라 해보자. s1은 1부터 6까지의 값을 가지게 되었고, s2는 4부터 9까지 값을 가지게 되었다.
In [11]:s1=set([1,2,3,4,5,6]) s2=set([4,5,6,7,8,9])
교집합¶
s1과 s2의 교집합을 구해보자.
In [12]:s1&s2
Out[12]:{4, 5, 6}
'&'기호를 사용하면 교집합을 간단히 구할 수 있다.
또는 다음과 같이 intersecion 함수를 사용해도 동일한 결과를 돌려준다.In [15]:s1.intersection(s2)
Out[15]:{4, 5, 6}
s2.intersecion(s1)을 사용해도 결과는 같다.
합집합¶
합집합은 다음과 같이 구할 수 있다. 이때 4,5,6처럼 중복해서 포함 값은 한개씩만 표현된다.
In [20]:s1|s2
Out[20]:{1, 2, 3, 4, 5, 6, 7, 8, 9}
'|'기호를 사용한 방법이다.
In [22]:s1.union(s2)
Out[22]:{1, 2, 3, 4, 5, 6, 7, 8, 9}
또는 union 함수를 사용하면 된다. 교집합에서 사용한 intersection함수와 마찬가지로 s2.union(s1)을 사용해도 동일한 결과를 돌려준다.
차집합¶
차지합은 다음과 같이 구할 수 있다.
In [23]:s1-s2
Out[23]:{1, 2, 3}
In [24]:s2-s1
Out[24]:{7, 8, 9}
빼기 (-)기호를 사용한 방법이다.
In [25]:s1.difference(s2)
Out[25]:{1, 2, 3}
In [26]:s2.difference(s1)
Out[26]:{7, 8, 9}
difference함수를 사용해도 차집합을 구할 수 있다.
In [29]:s1=set([1,2,3]) s1.add(4) s1
Out[29]:{1, 2, 3, 4}
값 여러개 추가하기(update)¶
여러 개의 값을 한번에 추가 할 떄는 다음과 같이 하면 된다.
In [30]:s1=set([1,2,3]) s1.update([3,4,5]) s1
Out[30]:{1, 2, 3, 4, 5}
특정값 제거하기(remove)¶
특정 값을 제거하고 싶을 때는 다음과 같이 하면 된다.
In [33]:s1=set([1,2,3]) s1.remove(2) s1
Out[33]:{1, 3}
출처 : "점프투파이썬"
'점프 투 파이썬' 카테고리의 다른 글
chapter02-8 자료형의 값을 저장하는 공간,변수 (0) 2021.09.07 chapter02-7 불 자료형 (0) 2021.09.07 chapter02-5 딕셔너리 자료형 (0) 2021.09.07 chapter02-4 튜플 자료형 (0) 2021.09.07 chapter02-3 리스트 자료형 (0) 2021.09.06