-
[Level 2] 전화번호 목록[프로그래머스] 코딩테스트 고득점 Kit/해시 2022. 10. 26. 23:05
[문제 설명]
전화번호부에 적힌 전화번호 중, 한 번호가 다른 번호의 접두어인 경우가 있는지 확인하려 합니다.
전화번호가 다음과 같을 경우, 구조대 전화번호는 영석이의 전화번호의 접두사입니다.- 구조대 : 119
- 박준영 : 97 674 223
- 지영석 : 11 9552 4421
전화번호부에 적힌 전화번호를 담은 배열 phone_book 이 solution 함수의 매개변수로 주어질 때, 어떤 번호가 다른 번호의 접두어인 경우가 있으면 false를 그렇지 않으면 true를 return 하도록 solution 함수를 작성해주세요.
제한 사항- phone_book의 길이는 1 이상 1,000,000 이하입니다.
- 각 전화번호의 길이는 1 이상 20 이하입니다.
- 같은 전화번호가 중복해서 들어있지 않습니다.
sort() 통해 각 전화번호 순서대로 정렬하여 인접한 앞 뒤만 비교
앞 전화번호와 뒤 전화번호 앞 전화번호 길이로 슬라이싱 한 것이 같으면 False
def solution(phone_book): phone_book.sort() for i in range(len(phone_book)-1): if phone_book[i] == (phone_book[i+1])[:len(phone_book[i])]: return False return True
'[프로그래머스] 코딩테스트 고득점 Kit > 해시' 카테고리의 다른 글
[Level 1] 폰켓몬 (0) 2022.10.26 [Level 1] 완주하지 못한 선수 (0) 2022.10.26