- 입문 - 문자열 정렬하기(1)2023년 11월 07일 22시 01분 28초에 업로드 된 글입니다.작성자: oneseel
입문 - 문자열 정렬하기(1)
문제설명
문자열 my_string이 매개변수로 주어질 때, my_string 안에 있는 숫자만 골라 오름차순 정렬한 리스트를 return 하도록 solution 함수를 작성해보세요.
제한사항
- 1 ≤ my_string의 길이 ≤ 100
- my_string에는 숫자가 한 개 이상 포함되어 있습니다.
- my_string은 영어 소문자 또는 0부터 9까지의 숫자로 이루어져 있습니다.
입출력 예
입출력 예 설명
입출력 예 #1
- "hi12392"에 있는 숫자 1, 2, 3, 9, 2를 오름차순 정렬한 [1, 2, 2, 3, 9]를 return 합니다.
입출력 예 #2
- "p2o4i8gj2"에 있는 숫자 2, 4, 8, 2를 오름차순 정렬한 [2, 2, 4, 8]을 return 합니다.
입출력 예 #3
- "abcde0"에 있는 숫자 0을 오름차순 정렬한 [0]을 return 합니다.
내 풀이
>> List를 이용해서 문자열에 있는 숫자를 List에 넣어서 배열로 바꾼 뒤 반환한다고 생각했지만, 막상 문자열에 있는 문자가 숫자인지 아닌지 확인하는 문제가 있었다.
>> 검색해본 결과 Character의 메서드 isDigit로 숫자인지 구별할 수 있었다. 또한 getNumbericValue라는 메서드로 문자로 된 숫자를 숫자로 바꿀 수 있었다.
>> 문자열을 문자들로 반복해서 돌면서 숫자인지 확인하고 숫자라면 numList에 넣고, sort를 이용해 오름차순으로 정렬한다.
>> 정렬된 numList를 배열로 바꾼 뒤, 반환한다.
import java.util.ArrayList; import java.util.List; class Solution { public int[] solution(String my_string) { List<Integer> numList = new ArrayList<>(); for (char c : my_string.toCharArray()) { if(Character.isDigit(c)) { int num = Character.getNumericValue(c); numList.add(num); } } numList.sort(null); int[] answer = new int[numList.size()]; for (int i = 0; i < numList.size(); i++) { answer[i] = numList.get(i); } return answer; } }
https://school.programmers.co.kr/learn/courses/30/lessons/120850
'코딩테스트' 카테고리의 다른 글
입문 - 소인수분해 (0) 2023.11.08 입문 - 숨어있는 숫자의 덧셈 (1) (0) 2023.11.08 입문 - 모음 제거 (1) 2023.11.06 입문 - 팩토리얼 (0) 2023.11.06 입문 - 최댓값 만들기(1) (0) 2023.11.06 댓글