[프로그래머스 / JAVA] Level 1 정수 내림차순으로 배치하기 (12933)
⏰ 2021-12-18 (토) 20:39:02
정수 내림차순으로 배치하기
랭크 | 사용 언어 |
---|---|
Level 1 |
문제 설명
함수 solution
은 정수 n
을 매개변수로 입력받습니다. n
의 각 자릿수를 큰것부터 작은 순으로 정렬한 새로운 정수를 리턴해주세요. 예를들어 n
이 118372면 873211을 리턴하면 됩니다.
제한 사항
n
은 1이상 8000000000 이하인 자연수입니다.
입출력 예
n | return |
---|---|
118372 | 873211 |
풀이
정수를 내림차순으로 배치한다. 역순이 아니라 숫자 크기별로 내림차순하여 정렬한 후 다시 숫자로 반환해야한다.
자연수 뒤집어 배열로 만들기 문제를 풀었다면 쉽게 풀이할 수 있다.
동일하게 자릿수별로 ArrayList
로 담은 이후에, Collections.sort()
로 정렬한다.
이후 다시 숫자를 자릿수별로 조립하여 온전한 숫자를 반환한다. int
로 반환하지 않도록 주의하자.
코드
JAVA
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43
import java.util.ArrayList; import java.util.Collections; /** * 정수 내림차순으로 배치하기 클래스 * * @author RWB * @since 2021.12.13 Mon 19:04:28 */ class Solution { /** * 해답 반환 메서드 * * @param n: [long] 자연수 * * @return [long] 해답 */ public long solution(long n) { long answer = 0; ArrayList<Integer> list = new ArrayList<>(); while (n >= 10) { list.add((int) (n % 10)); n /= 10; } list.add((int) n); Collections.sort(list); for (int i = 0; i < list.size(); i++) { answer += list.get(i) * Math.pow(10, i); } return answer; } }
🏷️ 태그
# 프로그래머스
# 알고리즘
# JAVA(자바)
# Level 1
읽어주셔서 고마워요!
도움이 되셨다면, 공감이나 댓글을 달아주시는 건 어떤가요?
블로그 운영에 큰 힘이 됩니다.