Algorithms/프로그래머스
[프로그래머스] Lv2. 전화번호 목록
devran
2023. 8. 12. 21:23
반응형
https://school.programmers.co.kr/learn/courses/30/lessons/42577
난 아직 해시를 잘 몰라서… 겨우겨우 했다
https://siahn95.tistory.com/96
위 링크가 개념 익히는데에 좋은 것 같음
문제
문제 설명
전화번호부에 적힌 전화번호 중, 한 번호가 다른 번호의 접두어인 경우가 있는지 확인하려 합니다.
전화번호가 다음과 같을 경우, 구조대 전화번호는 영석이의 전화번호의 접두사입니다.
- 구조대 : 119
- 박준영 : 97 674 223
- 지영석 : 11 9552 4421
전화번호부에 적힌 전화번호를 담은 배열 phone_book 이 solution 함수의 매개변수로 주어질 때, 어떤 번호가 다른 번호의 접두어인 경우가 있으면 false를 그렇지 않으면 true를 return 하도록 solution 함수를 작성해주세요.
풀이
코드가 정말 놀랍도록 짧다는 것 ,,, 다양한 모듈에 경이롭다
- HashSet (혹은 HashMap, 보통 HashMap이 시간복잡도에서 유리하다고 함) 을 만들어 반복문을 이용하여 phone_book의 정보를 순차적으로 넣어준다. 향상된 for문을 사용하면 더욱 간지가 나지만,, 난 그런 간지가 중요치 않다.
- 각 phone_book을 모두 탐색하고 앞서만든 set에 contains로 확인후에 있으면 false
- 정말 간단하다..
import java.util.*;
class Solution {
public boolean solution(String[] phone_book) {
Set<String> set = new HashSet<>(); //Hashset 만들기
for(int i = 0; i < phone_book.length; i++ )
set.add(phone_book[i]); //set에 순차적으로 넣어주기
for(int i = 0; i < phone_book.length; i++ ){
for (int j = 1; j < phone_book[i].length(); j++) {
if (set.contains(phone_book[i].substring(0, j))) {
return false;
}
}
}
return true;
}
}
반응형