ABOUT ME

-

Today
-
Yesterday
-
Total
-
  • [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
Designed by Tistory.