[알고리즘 풀이] 프로그래머스 LV2 '전화번호 목록'

Taewan Kim·2019년 2월 3일
0
post-thumbnail

문제설명

전화번호부에 적힌 전화번호 중, 한 번호가 다른 번호의 접두어인 경우가 있는지 확인하려 합니다.
전화번호가 다음과 같을 경우, 구조대 전화번호는 영석이의 전화번호의 접두사입니다.

구조대 : 119
박준영 : 97 674 223
지영석 : 11 9552 4421

전화번호부에 적힌 전화번호를 담은 배열 phone_book 이 solution 함수의 매개변수로 주어질 때, 어떤 번호가 다른 번호의 접두어인 경우가 있으면 false를 그렇지 않으면 true를 return 하도록 solution 함수를 작성해주세요.

제한조건

phone_book의 길이는 1 이상 1,000,000 이하입니다.

각 전화번호의 길이는 1 이상 20 이하입니다.

예시

  • phone_book = [119, 97674223, 1195524421]
    첫번째 인덱스인 119가 세번째 인덱스인 1195524421에 포함되어 있어서 return False
  • phone_book = [123,456,789]
    어느 것도 서로 포함관계가 없기 때문에 return True
  • phone_book = [12,123,1235,567,88]
    첫번째 인덱스인 12가 두번째 인덱스인 123과 1235에 속에 있으므로 return False

해설

def solution(phone_book):
    phone_book = list(map(str, phone_book))

    first = phone_book[0]

    answer =[]
    for i in phone_book:
        if first == i:
            continue
        elif first == i[0:len(first)] or i == first[0:len(i)]:
            answer.append("False")
        else:
            answer.append("True")
    if "False" in answer:
        return False
    else:
        return True
  1. 우선 int로 되어있는 phone_book을 map을 이용해서 str타입으로 바꿔줍니다.

  2. 처음 반복문에서는 phone_book에 있는 원소를 하나씩 꺼내서 비교합니다. 처음 조건문은 first == i일 경우 스킵하고 다음으로 넘어가는 continue를, 다음 조건문을 이용해서 서로 포함관계에 있는지 확인을 합니다.
    elif first == i[0:len(first)] or i == first[0:len(i)]:

  1. 이렇게 전체적으로 answer라는 리스트에 True와 False문자열이 들어가게 되는데 하나라도 포함관계가 있으며 False값이 있으므로 return False, 그 이외에는 answer에 True값만 있으므로 return True입니다.

채점결과

레벨2_전화번호목록.PNG

profile
안드로이드 네이티브 앱 개발과 파이썬 공부중인 문과전공 대학생입니다 :)

0개의 댓글