[프로그래머스]문자열 정렬하기 (1)
문자열 정렬하기 (1)
문제 설명
문자열 my_string이 매개변수로 주어질 때, my_string 안에 있는 숫자만 골라 오름차순 정렬한 리스트를 return 하도록 solution 함수를 작성해보세요.
제한사항
- 1 ≤ my_string의 길이 ≤ 100
- my_string에는 숫자가 한 개 이상 포함되어 있습니다.
- my_string은 영어 소문자 또는 0부터 9까지의 숫자로 이루어져 있습니다
입출력 예
my_string | result |
---|---|
“hi12392” | [1, 2, 2, 3, 9] |
“p2o4i8gj2” | [2, 2, 4, 8] |
“abcde0” | [0] |
입출력 예 설명
입출력 예 #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 합니다.
나의 풀이 코드
import java.util.Arrays;
class Solution {
public int[] solution(String my_string) {
my_string=my_string.replaceAll("[a-z]" , "");
int[] answer = new int[my_string.length()];
char[] ch_arr = new char[my_string.length()];
for (int i=0; i<my_string.length(); i++) {
ch_arr[i] = my_string.charAt(i);
}
Arrays.sort(ch_arr);
for (int i=0; i<my_string.length(); i++) {
answer[i] = Character.getNumericValue(ch_arr[i]);
}
return answer;
}
}
문자제거를 제거한 sting -> char배열 -> 정렬 -> int배열 순으로 하였다.
배운점
import java.util.*;
class Solution {
public int[] solution(String my_string) {
my_string = my_string.replaceAll("[a-z]","");
int[] answer = new int[my_string.length()];
for(int i =0; i<my_string.length(); i++){
answer[i] = my_string.charAt(i) - '0';
}
Arrays.sort(answer);
return answer;
}
}
다른사람이 푼 코드를 보면 string에서 바로 int로 바꾸는데
my_string.charAt(i) - ‘0’;에서 -‘0’을 해주어 아스키가 아닌 문자 그대로의 정수가 나온다.
import java.util.*;
class Solution {
public int[] solution(String myString) {
return Arrays.stream(myString.replaceAll("[A-Z|a-z]", "")
.split(""))
.sorted()
.mapToInt(Integer::parseInt)
.toArray();
}
}
스트림에서도 마찬가지로
.replaceAll(“[A-Z|a-z]”, “”) 문자 제거후
.split(“”) 배열로 만들고
.mapToInt(Integer::parseInt) 정렬하고
.mapToInt(Integer::parseInt) 정수로 변환하고
.toArray(); 배열로 반환한다.
Leave a comment