반응형

 

[광고 누르면 오늘의 행운 상승!!]

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

 

코딩테스트 연습 - 전화번호 목록

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

programmers.co.kr

1. 구현

String 배열을 정렬하게 되면 사전순으로 정렬이 된다.
aaa, abc, aaa, ddd, 가 있다면
aaa, aaa, abc, ddd 순으로 정렬이 된다.
i번째와 i+1번째를 비교하면서 같다면 false를 리턴해주면 된다.
단, i의 길이가 i+1의 길이를 초과한다면 continue 시켜준다.

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].length() > phone_book[i+1].length()) continue;
	            if(phone_book[i].equals(phone_book[i+1].substring(0,phone_book[i].length()))){
	                return false;           
	            }
	        }
	        return true;
	    }
	}
	
반응형

+ Recent posts