Skip to content

Commit 4d76067

Browse files
committed
[level 2] Title: 전화번호 목록, Time: 352.15 ms, Memory: 209 MB -BaekjoonHub
1 parent 5ceea16 commit 4d76067

File tree

2 files changed

+104
-0
lines changed

2 files changed

+104
-0
lines changed
Lines changed: 84 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,84 @@
1+
# [level 2] 전화번호 목록 - 42577
2+
3+
[문제 링크](https://school.programmers.co.kr/learn/courses/30/lessons/42577?language=java)
4+
5+
### 성능 요약
6+
7+
메모리: 209 MB, 시간: 352.15 ms
8+
9+
### 구분
10+
11+
코딩테스트 연습 > 해시
12+
13+
### 채점결과
14+
15+
정확성: 83.3<br/>효율성: 16.7<br/>합계: 100.0 / 100.0
16+
17+
### 제출 일자
18+
19+
2025년 11월 29일 16:04:48
20+
21+
### 문제 설명
22+
23+
<p>전화번호부에 적힌 전화번호 중, 한 번호가 다른 번호의 접두어인 경우가 있는지 확인하려 합니다.<br>
24+
전화번호가 다음과 같을 경우, 구조대 전화번호는 영석이의 전화번호의 접두사입니다.</p>
25+
26+
<ul>
27+
<li>구조대 : 119</li>
28+
<li>박준영 : 97 674 223</li>
29+
<li>지영석 : 11 9552 4421</li>
30+
</ul>
31+
32+
<p>전화번호부에 적힌 전화번호를 담은 배열 phone_book 이 solution 함수의 매개변수로 주어질 때, 어떤 번호가 다른 번호의 접두어인 경우가 있으면 false를 그렇지 않으면 true를 return 하도록 solution 함수를 작성해주세요.</p>
33+
34+
<h5>제한 사항</h5>
35+
36+
<ul>
37+
<li>phone_book의 길이는 1 이상 1,000,000 이하입니다.
38+
39+
<ul>
40+
<li>각 전화번호의 길이는 1 이상 20 이하입니다.</li>
41+
<li>같은 전화번호가 중복해서 들어있지 않습니다.</li>
42+
</ul></li>
43+
</ul>
44+
45+
<h5>입출력 예제</h5>
46+
<table class="table">
47+
<thead><tr>
48+
<th>phone_book</th>
49+
<th>return</th>
50+
</tr>
51+
</thead>
52+
<tbody><tr>
53+
<td>["119", "97674223", "1195524421"]</td>
54+
<td>false</td>
55+
</tr>
56+
<tr>
57+
<td>["123","456","789"]</td>
58+
<td>true</td>
59+
</tr>
60+
<tr>
61+
<td>["12","123","1235","567","88"]</td>
62+
<td>false</td>
63+
</tr>
64+
</tbody>
65+
</table>
66+
<h5>입출력 예 설명</h5>
67+
68+
<p>입출력 예 #1<br>
69+
앞에서 설명한 예와 같습니다.</p>
70+
71+
<p>입출력 예 #2<br>
72+
한 번호가 다른 번호의 접두사인 경우가 없으므로, 답은 true입니다.</p>
73+
74+
<p>입출력 예 #3<br>
75+
첫 번째 전화번호, “12”가 두 번째 전화번호 “123”의 접두사입니다. 따라서 답은 false입니다.</p>
76+
77+
<hr>
78+
79+
<p><strong>알림</strong></p>
80+
81+
<p>2021년 3월 4일, 테스트 케이스가 변경되었습니다. 이로 인해 이전에 통과하던 코드가 더 이상 통과하지 않을 수 있습니다.</p>
82+
83+
84+
> 출처: 프로그래머스 코딩 테스트 연습, https://school.programmers.co.kr/learn/challenges
Lines changed: 20 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,20 @@
1+
import java.util.*;
2+
3+
class Solution {
4+
public boolean solution(String[] phone_book) {
5+
Map<String, Integer> hashMap = new HashMap<>();
6+
7+
for (int i = 0; i < phone_book.length; i++) {
8+
hashMap.put(phone_book[i], i);
9+
}
10+
11+
for (int i = 0; i < phone_book.length; i++) {
12+
for (int j = 1; j < phone_book[i].length(); j++) {
13+
String prefix = phone_book[i].substring(0, j);
14+
if (hashMap.containsKey(prefix)) return false;
15+
}
16+
}
17+
18+
return true;
19+
}
20+
}

0 commit comments

Comments
 (0)