본문 바로가기
JAVA

프로그래머스 코딩테스트 연습 (Hash) 전화번호 목록도움말

by 열정적인 이찬형 2021. 11. 16.

문제 링크

프로그래머스
코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요.
programmers.co.kr
 

문제 설명

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

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

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


제한사항

  • phone_book의 길이는 1 이상 1,000,000 이하입니다.
    • 각 전화번호의 길이는 1 이상 20 이하입니다.
    • 같은 전화번호가 중복해서 들어있지 않습니다.

문제 결과

입출력 예 #1
앞에서 설명한 예와 같습니다.

입출력 예 #2
한 번호가 다른 번호의 접두사인 경우가 없으므로, 답은 true입니다.

입출력 예 #3
첫 번째 전화번호, “12”가 두 번째 전화번호 “123”의 접두사입니다. 따라서 답은 false입니다.


접근 방법

  • 전화번호를 Key값으로 가지며 접두사를 조사하기 위해 전화번호의 길이를 Value를 갖는 HashMap을 만든다.
  • 반복문을 통해서 전화번호와 길이를 HashMap를 형성
  • Key값을 받아와서 키 값에 substring을 통해 순차적으로 접두사와 동일한 Key값이 있는지 확인하는 방식(containsKey)을 사용하였습니다.

결과 코드

import java.util.*;
class Solution {
    public boolean solution(String[] phone_book) {
        Boolean answer;
        HashMap<String,Integer> phone = new HashMap<>();		//HashMap 작성
        for(String number : phone_book){
            phone.put(number,number.length());	
            //Map에 전화번호를 Key값으로 전화번호 길이를 Value로 넣음
        }
        for(String key : phone.keySet()){
            for(int i=1;i<phone.get(key);i++){
                if(phone.containsKey(key.substring(0,i)))
                //Key값을 Substring하고 같은 key값이 있는지 확인하는 반복문
                    return false;
            }
        }
        return true;
    }
}

참고

  • 문제를 풀고 난 뒤에 다른 사람들의 풀이를 확인해보았을 때에 startsWith()을 사용하는 코드를 보게 되었습니다.
  • startsWith()를 쓴 코드가 간결해보여서 사용해보았는데 효율성 문제에서 실패하였습니다.
  • 혹시.... startsWith()을 사용해서 통과하신 분이 있으면 댓글로 남겨주세요!

댓글