[Python] [백준 #1764] 두 개의 set(집합) 중복 요소 출력하기

2024. 5. 10. 15:31· Languages/Python
목차
  1. set(집합)

 

비교적 쉬운 문제였다. (내가 풀 정도^^)

 

여기서 나는 '듣'과 '보'의 중복 요소를 set(집합)을 사용하여

굉장히 편하게 풀었다.

 

근데 그냥 내 머리로만 한 건 아니고.. 구글링을 살짝 해서

잊지 않게 정리하려 한다.

 

일단 아래는 내가 푼 전체 코드이다.

import sys
input = sys.stdin.readline

# 듣 N
# 보 M
N, M = map(int, input().split())

D = [input().strip() for i in range(N)] // strip() 사용하여 문자열 앞 뒤 공백 제거
B = [input().strip() for j in range(M)]

DB = sorted(set(D) & set(B)) // 사전 순 정렬
print(len(DB)) // 중복 요소 개수
# print(DB)
for i in DB:
    print(i)

 

일단 듣도 못한은 D, 보도 못한은 B로 두고 배열에 넣었다.

겹치는 요소를 찾기 위해 배열 반복문을 돌리면 시간 복잡도가 높을 것이라 생각하고

구글링을 해보니 set을 사용하면 간편하게 & 만으로 중복 요소를 찾을 수 있음을 알게 됐다.

 

이제 set(집합)을 정리해보자.

 

set(집합)

python에서 집합은 고유한 요소의 모음이다.

- 순서가 없다 (인덱스로 접근하지 못한다)

- 중복이 허용되지 않는다

- 요소는 변경 불가능한 자료형만 사용할 수 있다

set_example = set([1, 2, 3, 4, 5])
print(set_example)
>>> {1, 2, 3, 4, 5}

 

set은 중복이 허용되지 않으므로

중복된 요소를 합쳐줄 수 있다.

 

1. 교집합

set1 = set([1,2,3,4,5,6])
set2 = set([3,4,5,6,8,9])

print(set1 & set2)
print(set1.intersection(set2))

-----------------------------------------------------------
{3, 4, 5, 6}
{3, 4, 5, 6}

 

2. 합집합

set1 = set([1,2,3,4,5,6])
set2 = set([3,4,5,6,8,9])


print(set1 | set2)
print(set1.union(set2))

-----------------------------------------------------------
{1, 2, 3, 4, 5, 6, 8, 9}
{1, 2, 3, 4, 5, 6, 8, 9}

 

3. 차집합

set1 = set([1,2,3,4,5,6])
set2 = set([3,4,5,6,8,9])


print(set1 - set2)
print(set1.difference(set2))

-----------------------------------------------------------
{1, 2}
{1, 2}

 

중복 요소 찾기 set과 list 비교

A = [1, 3, 5, 7, 9]
B = [10, 5, 1, 2, 4]

C = set(A) & set(B) // set 사용
D = [i for i in A if i in B] // list 사용

print(C)
print(D)

-----------------------------------------------------------
print(C) ==>{1, 5} 
print(D) ==> [1, 5]

 

이 방법으로 중복 요소를 찾았고,

set은 순서가 없고 인덱스로 접근할 수 없으므로

sorted(set)을 통해 문제의 '사전순 출력' 조건을 충족했다.

'Languages > Python' 카테고리의 다른 글

[Python] leetcode | 20. Valid Parentheses 괄호 짝 맞추기 | Stack  (0) 2024.05.26
[Python] 프로그래머스 | 같은 숫자는 싫어 | append  (0) 2024.05.24
[Python] [백준 #20291] Counter로 배열 요소 개수 세기  (0) 2024.05.10
[Python] 파이썬 sys.stdin.readline() 입력 받기  (0) 2024.04.02
[Python] 파이썬의 나누기(몫/나머지) // 연산자와 % 연산자  (0) 2023.04.10
  1. set(집합)
'Languages/Python' 카테고리의 다른 글
  • [Python] 프로그래머스 | 같은 숫자는 싫어 | append
  • [Python] [백준 #20291] Counter로 배열 요소 개수 세기
  • [Python] 파이썬 sys.stdin.readline() 입력 받기
  • [Python] 파이썬의 나누기(몫/나머지) // 연산자와 % 연산자
효딩
효딩
개ㄱ발은 기세다. 줄여서 객기.
hyoding개ㄱ발은 기세다. 줄여서 객기.
효딩
hyoding
효딩
전체
오늘
어제
  • 분류 전체보기 (245)
    • SKKU SW (30)
      • Computer Architecture (14)
      • Database (4)
      • Computer Network (3)
      • Operating System (7)
      • Mobile App Programming (2)
    • SuperCoding (68)
    • CS (8)
    • Web Programming (19)
    • Cloud (13)
    • Languages (45)
      • Python (8)
      • Java (37)
    • Supporters (8)
      • MoteMote (6)
      • NHN Cloud (2)
    • Certification (27)
      • Network Advisor (14)
      • ADsP (10)
      • Engineer Information Proces.. (3)
    • Finance (9)
      • 경제금융용어 (3)
    • Woori FISA (14)

블로그 메뉴

  • 홈
  • 태그
  • 방명록

공지사항

인기 글

태그

  • 우리fis아카데미
  • nhn cloud
  • 서버생성
  • 서버개발
  • K-디지털트레이닝
  • 코틀린문법
  • Kotlin
  • 네트워크관리사 후기
  • 우리FISA
  • 클라우드서비스개발
  • 앱개발
  • 인프라
  • rds local 접속
  • 코틀린
  • 네트워크관리사
  • 네트워크관리사 합격
  • 인프라개발
  • 글로벌소프트웨어캠퍼스
  • 우리에프아이에스
  • 봐
  • 클라우드
  • 네트워크관리사2급
  • 서버배포
  • 클라우드 서비스
  • 네트워크관리사2급 필기
  • 네트워크관리사 준비물
  • 네트워크관리사 커트라인
  • 네트워크관리사2급 공부방법
  • AWS
  • apppaas

최근 댓글

최근 글

hELLO · Designed By 정상우.v4.2.2
효딩
[Python] [백준 #1764] 두 개의 set(집합) 중복 요소 출력하기
상단으로

티스토리툴바

단축키

내 블로그

내 블로그 - 관리자 홈 전환
Q
Q
새 글 쓰기
W
W

블로그 게시글

글 수정 (권한 있는 경우)
E
E
댓글 영역으로 이동
C
C

모든 영역

이 페이지의 URL 복사
S
S
맨 위로 이동
T
T
티스토리 홈 이동
H
H
단축키 안내
Shift + /
⇧ + /

* 단축키는 한글/영문 대소문자로 이용 가능하며, 티스토리 기본 도메인에서만 동작합니다.