Study/Java

[Java 자바] 프로그래머스 Lv 1 - 문자열 내 마음대로 정렬하기

1.jun 2025. 1. 24. 13:18
728x90
반응형

 

 

코딩테스트 연습 | 프로그래머스 스쿨

개발자 취업의 필수 관문 코딩테스트를 철저하게 연습하고 대비할 수 있는 문제를 총망라! 프로그래머스에서 선발한 문제로 유형을 파악하고 실력을 업그레이드해 보세요!

school.programmers.co.kr

 

목차
  1. 문제 설명
  2. 입출력 예시
  3. 문제 풀이

 

 


1. 문제 설명

 

 

728x90

 

문제 설명

문자열로 구성된 리스트 strings와, 정수 n이 주어졌을 때,
각 문자열의 인덱스 n번째 글자를 기준으로 오름차순 정렬하려 합니다.
예를 들어 strings가 ["sun", "bed", "car"]이고 n이 1이면 각 단어의 인덱스 1의 문자 "u", "e", "a"로 strings를 정렬합니다.

 

 

제한사항

  • strings는 길이 1 이상, 50이하인 배열입니다.
  • strings의 원소는 소문자 알파벳으로 이루어져 있습니다.
  • strings의 원소는 길이 1 이상, 100이하인 문자열입니다.
  • 모든 strings의 원소의 길이는 n보다 큽니다.
  • 인덱스 1 문자가 같은 문자열이 여럿 경우, 사전순으로 앞선 문자열이 앞쪽에 위치합니다.

 

 

 

 


2. 입출력 예시

 

 

 

 

입출력 예시

#1 

"sun", "bed", "car"의 1번째 인덱스 값은 각각 "u", "e", "a" 입니다.
이를 기준으로 strings를 정렬하면 ["car", "bed", "sun"] 입니다.

 

#2

"abce"와 "abcd", "cdx"의 2번째 인덱스 값은 "c", "c", "x"입니다.
따라서 정렬 후에는 "cdx"가 가장 뒤에 위치합니다.
"abce"와 "abcd"는 사전순으로 정렬하면 "abcd"가 우선하므로, 답은 ["abcd", "abce", "cdx"] 입니다.

 

 

 

 

 


3. 문제 풀이

반응형

 

문제 풀이

import java.util.*;

class Solution {
    public String[] solution(String[] strings, int n) {
        String[] answer = new String[strings.length];
        
        // n번째 인수를 맨 앞에 두고 배열 설정
        for(int i=0; i<strings.length; i++){
            answer[i] = strings[i].substring(n,n+1) + strings[i];
        }
        
        // 오름차순 정렬
        Arrays.sort(answer);
        
        // 맨 앞 글자 빼기
          for(int i=0; i<strings.length; i++){
            answer[i] = answer[i].substring(1);
        }
        return answer;
    }
}

 

 

 

 

728x90
반응형