250x250
Notice
Recent Posts
Recent Comments
관리 메뉴

탁월함은 어떻게 나오는가?

[Algorithm] 전화번호 목록 (Programmers - JavaScript) 본문

[Snow-ball]프로그래밍(컴퓨터)/Algorithm Training

[Algorithm] 전화번호 목록 (Programmers - JavaScript)

Snow-ball 2023. 10. 7. 14:55
반응형

문제 설명

전화번호부에 적힌 번화번호 중, 한 번호가 다른 번호의 접두어인 경우가 있는지 확인하려 합니다.

전화번호가 다름과 같을 경우, 구조대 전화번호는 영석이의 전화번호의 접두사입니다.

 

- 구조대 : 119

- 박준영 : 97 674 223

- 지영석 : 11 9552 4421

 

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

 

 

 


 

 

 

제한 사항

 

 

 


 

 

 

입출력 예제

 

 

 


 

 

 

입출력 예 설명

입출력 예 #1

앞에서 설명한 예와 같습니다.

입출력 예 #2

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

입출력 예 #3

첫 번째 전화번호, "12"가 두 번째 전화번호 "123"의 접두사입니다. 따라서 답은 false입니다.

 

 

 


 

 

 

문제 풀이

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
function solution(phone_book) {
  const map = new Map();
  const sort_phone_book = phone_book.sort();
 
  sort_phone_book.forEach((phone_number) =>
    map.set(phone_number, phone_number)
  );
 
  for (let i = 0; i < sort_phone_book.length - 1++i) {
    const value = map
      .get(sort_phone_book[i + 1])
      .substring(0, sort_phone_book[i].length);
 
    if (map.get(sort_phone_book[i]) === value) {
      return false;
    }
  }
 
  return true;
}
cs

 

 

 

 

 

 

https://school.programmers.co.kr/learn/courses/30/lessons/42577

 

프로그래머스

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

programmers.co.kr

 

반응형
Comments