[프로그래머스 / JAVA] Level 1 자연수 뒤집어 배열로 만들기 (12932)
⏰ 2021-12-18 (토) 18:58:31
자연수 뒤집어 배열로 만들기
랭크 | 사용 언어 |
---|---|
Level 1 |
문제 설명
자연수 n
을 뒤집어 각 자리 숫자를 원소로 가지는 배열 형태로 리턴해주세요. 예를들어 n
이 12345이면 [5,4,3,2,1]을 리턴합니다.
제한 사항
n
은 10,000,000,000이하인 자연수입니다.
입출력 예
n | return |
---|---|
12345 | { 5, 4, 3, 2, 1 } |
풀이
자연수 n
을 역순으로 뒤집어 각 숫자를 배열로 반환한다.
숫자를 문자열로 바꾸고, 각 문자를 역순으로 배열하는 방법도 있다. 하지만 이 번엔 숫자 연산을 통해 구해본다.
ArrayList
를 선언하여 각 숫자를 담는다.
JAVA
1 2 3 4 5 6 7 8 9 10
ArrayList<Integer> list = new ArrayList<>(); while (n >= 10) { list.add((int) (n % 10)); n /= 10; } list.add((int) n);
n % 10
으로 자릿수를 구할 수 있고, n / 10
으로 해당 자릿수를 제외한 나머지 숫자를 구할 수 있다. 이후 n
이 10보다 작아질 때까지 반복하여 연산을 수행한다.
1의 자리부터 구하기 때문에, 굳이 역순으로 돌릴 필요 없이 담은 배열을 그대로 반환하면 된다.
코드
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
import java.util.ArrayList; /** * 자연수 뒤집어 배열로 만들기 클래스 * * @author RWB * @since 2021.12.13 Mon 18:31:27 */ class Solution { /** * 해답 반환 메서드 * * @param n: [long] 자연수 * * @return [int[]] 해답 */ public int[] solution(long n) { ArrayList<Integer> list = new ArrayList<>(); while (n >= 10) { list.add((int) (n % 10)); n /= 10; } list.add((int) n); return list.stream().mapToInt(Integer::intValue).toArray(); } }
🏷️ 태그
# 프로그래머스
# 알고리즘
# JAVA(자바)
# Level 1
읽어주셔서 고마워요!
도움이 되셨다면, 공감이나 댓글을 달아주시는 건 어떤가요?
블로그 운영에 큰 힘이 됩니다.