Notice
Recent Posts
Recent Comments
Link
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |
Tags
- 호이스팅
- cpu
- computerscience
- CSS
- 너비우선탐색
- KAKAO
- git
- 패스트캠퍼스
- html/css/js
- DFS
- 그리디
- 코딩테스트
- 백준
- CS
- 부트캠프
- js
- 컴퓨터공학
- 컴퓨터과학
- 야놀자
- 국비지원취업
- nodejs
- 코테
- github
- 자바스크립트
- 국비지원
- 프론트엔드개발자
- Javascript
- LinkSnap
- BFS
- 알고리즘
Archives
- Today
- Total
My Boundary As Much As I Experienced
전화번호 목록(프로그래머스 레벨2, 해시, JavaScript 풀이) 본문
https://school.programmers.co.kr/learn/courses/30/lessons/42577
오랜만에 프로그래머스로 복귀했다. 레벨2 남은거 다 풀고 레벨3 풀기 시작해야겠다.
문제 수준:
레벨2
문제 요약:
전화번호부에 적힌 전화번호 중, 한 번호가 다른 번호의 접두어인 경우가 있는지 확인하려 합니다.
전화번호가 다음과 같을 경우, 구조대 전화번호는 영석이의 전화번호의 접두사입니다.
- 구조대 : 119
- 박준영 : 97 674 223
- 지영석 : 11 9552 4421
전화번호부에 적힌 전화번호를 담은 배열 phone_book 이 solution 함수의 매개변수로 주어질 때, 어떤 번호가 다른 번호의 접두어인 경우가 있으면 false를 그렇지 않으면 true를 return 하도록 solution 함수를 작성해주세요.
입출력 예 (입력 / 출력):
문제 풀이 전략:
문제 유형부터 hash라고 하는걸 보면 해시테이블 자료구조를 사용하라는거 같지만,
가장 구현이 쉬워보이는 for문 반복과 includes메소드로 포함여부 비교로 한 번 구현해보았다.
function solution(phone_book) {
let bookCopy = phone_book.sort((a,b) => a.length - b.length) // 짧은게 먼저 정렬되도록.
let result = true;
for (let i = 0; i < bookCopy.length; i++) {
const target = bookCopy[i] // 타겟 하나 정하기
for (let j = i + 1; j < bookCopy.length; j++) {
const judge = bookCopy[j].includes(target) // 다른 요소들에 이게 포함되어 있는지 비교
if (judge) { // 포함되어있다면
result = false; // result를 false로 만들고
break // break!
}
}
if (!result) { // result가 false면
break // 상위 for문도 break!
}
}
return result // 제출
}
그 결과, 10개의 테스트 케이스 중에 8개 맞고, 시간 복잡도 테스트는 4개 중 1개 통과하는 코드가 나왔다.
위 이중포문 방식이 시간복잡도를 통과 못할거라는 예측은 했는데 테케 중에 틀린게 나올거란 예상은 못했다.
어떤 부분에서 예외가 발생한 것일까? 그건 모르겠지만 해시비교로 전환해보았다.
내 풀이:
compareText라는 함수를 만들어서 사용했다.
function solution(phone_book) {
let bookCopy = phone_book.sort((a,b) => a.length - b.length) // 짧은게 앞으로 오게 정렬
let obj = {}; // 해시 테이블 하나 만들기
let result = true;
for (let i = 0; i < bookCopy.length; i++) {
const target = bookCopy[i] // 현재 인덱스 타겟을
obj[target] = true; // 해시테이블에 입력
result = compareText(target, obj); // compareText라는 함수를 만들어서 코드 스플리팅을 해뒀다.
if (!result) { // result가 false면
break // break
}
}
return result // 정답제출
}
function compareText (txt, obj) {
for (let i = 0; i < txt.length; i++) {
const target = txt.slice(0, i + 1); // 만약 숫자가 123이라면 1, 12, 123 이렇게 다 조합해볼 수 있게 된다.
if (target !== txt && obj[target]) { // 타겟과 원래 단어가 똑같다면 무조건 true가 나오기 때문에 그 경우의 수는 제외하고, 해시테이블에 타겟이 있는지 비교
return false
}
}
return true
}
'Algorithm > Coding Test' 카테고리의 다른 글
마인크래프트(백준 코딩테스트 18111번, 구현/브루트포스, NodeJS 풀이) (0) | 2024.05.06 |
---|---|
행렬 곱셈(백준 2740번, 수학/구현, NodeJS풀이) (0) | 2024.03.29 |
우승자는 누구?(백준 코딩테스트 5179번, 구현/정렬, NodeJS 풀이) (0) | 2024.03.27 |
태보태보 총난타(백준 코딩테스트 17249번, 문자열, NodeJS 풀이) (0) | 2024.03.24 |
귀여운 수~ε٩(๑> ₃ <)۶з(백준 코딩테스트 17294번, 문자열, NodeJS 풀이) (0) | 2024.03.24 |