[프로그래머스|JAVA] 전화번호 목록 | startsWith(), sort 사용 ⭕️ | HashSet 사용 ❌

2025. 7. 31. 19:26·💻코딩/💡Programmers
728x90
반응형

[문제]

 

프로그래머스

SW개발자를 위한 평가, 교육의 Total Solution을 제공하는 개발자 성장을 위한 베이스캠프

programmers.co.kr

 

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

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

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

 


 

[코드]

import java.util.*;

class Solution {
    public boolean solution(String[] phone_book) {
        
        Arrays.sort(phone_book);
        
        for(int i = 0; i < phone_book.length - 1; i++){
            if(phone_book[i+1].startsWith(phone_book[i])) return false;
        }
        return true;
    }
}

 

접근법

  1. 배열 정렬 (기본 오름차순)
    • 접두사가 되기 쉬운 짧은 문자열을 앞으로 배치
  2. startsWith()를 사용하여 phone_book[i]로 시작하는지 확인
  3. 시작하면 false 반환
  4. 아니라면 true 반환

 


짧게나마 startsWith()에 대해 다루자면..

 

startsWith()란?
문자열이 특정 문자열로 시작하는지를 확인하는 메서드

 

✅ 사용법

boolean startsWith(String prefix) //boolean 타입
항목 설명
대소문자 "Java" != "java"  (false)
공백 접두사에 공백이 포함되면 정확히 일치해야 함
null 체크 null 문자열에서 호출 시 NullPointerException 발생 가능

 

 

 

 

 

✅  startsWith()    VS   equals()

메서드 설명
startsWith() 접두사만 비교
equals() 전체 문자열이 같은지 비교

 

 

✚ startsWith()는 문자열이 특정 문자열로 시작하는지를 빠르게 검사할 수 있는 메서드로, 명령어 파싱, 파일 경로 분석, URL 필터링 등 다양한 상황에서 쓰인다.

 

 


 

 

프로그래머스 [질문하기]를 통해 배열의 정렬을 이용하면 된다는 힌트를 얻었다.

조금만 더 깊게 생각하면 문제가 아주 쉬워진다는 것이 신기하다.

 

 

 

728x90
반응형

'💻코딩 > 💡Programmers' 카테고리의 다른 글

[프로그래머스|JAVA] 가장 큰 수 찾기 | Level 0  (0) 2025.08.14
[프로그래머스|JAVA] 자연수 뒤집어 배열로 만들기 | Stream 방식  (1) 2025.08.14
[프로그래머스|MySQL] 대여 횟수가 많은 자동차들의 월별 대여 횟수 구하기 | 서브쿼리, MONTH(), IN(), BETWEEN AND, GROUP BY, HAVING  (2) 2025.07.10
[프로그래머스|JAVA] 피로도 | 완전탐색 dfs | 백트래킹  (0) 2025.07.10
[프로그래머스|MySQL] 진료과별 총 예약 횟수 출력하기 | COUNT(), LIKE, GROUP BY  (2) 2025.07.08
'💻코딩/💡Programmers' 카테고리의 다른 글
  • [프로그래머스|JAVA] 가장 큰 수 찾기 | Level 0
  • [프로그래머스|JAVA] 자연수 뒤집어 배열로 만들기 | Stream 방식
  • [프로그래머스|MySQL] 대여 횟수가 많은 자동차들의 월별 대여 횟수 구하기 | 서브쿼리, MONTH(), IN(), BETWEEN AND, GROUP BY, HAVING
  • [프로그래머스|JAVA] 피로도 | 완전탐색 dfs | 백트래킹
망꼬누나
망꼬누나
공부한 내용을 정리하는 공간입니다.
  • 망꼬누나
    망꼬누나의 개발 공부
    망꼬누나
  • 전체
    오늘
    어제
    • 분류 전체보기 (165)
      • ℹ️ 정보 및 실습 (19)
        • ☑️ Git & GitHub (8)
        • ☑️ 프로젝트 (6)
        • ☑️ 회고 및 후기 (5)
      • 🛠 CS (1)
      • 💻코딩 (88)
        • 💡Baekjoon (17)
        • 💡Programmers (71)
      • ✏️공부 (48)
        • 💡OS (1)
        • 💡Network (6)
        • 💡SpringBoot (9)
        • 💡JAVA (21)
        • 💡SQL (1)
        • 💡DB (2)
        • ☁️ Cloud (4)
        • 💡알고리즘 (4)
      • 📌 자격증 (6)
        • 📝정보처리기사 (3)
        • 📝SQLD (3)
  • 블로그 메뉴

    • 홈
    • github
  • 나의 GitHub Contribution 그래프
    Loading data ...
  • 인기 글

  • 태그

    map
    S3
    자바
    Java
    Set
    트랜잭션
    코딩테스트
    데브코스
    GIT
    github
    동시성제어
    자료구조
    Stream
    baekjoon
    프로그래머스
    알고리즘
    네트워크
    AWS
    백엔드
    프로그래머스 #JAVA
  • 최근 댓글

  • 최근 글

  • 250x250
    반응형
  • hELLO· Designed By정상우.v4.10.5
망꼬누나
[프로그래머스|JAVA] 전화번호 목록 | startsWith(), sort 사용 ⭕️ | HashSet 사용 ❌
상단으로

티스토리툴바