자연수 n을 뒤집어 각 자리 숫자를 원소로 가지는 배열 형태로 리턴해주세요. 예를 들어, n이 12345이면 [5,4,3,2,1]을 리턴합니다.
n | answer |
---|---|
12345 | [5,4,3,2,1] |
class Solution {
public int[] solution(long n) {
String nString = String.valueOf(n);
int[] answer = new int[nString.length()];
for(int i = 0; i < nString.length(); i++) {
answer[i] = Integer.parseInt(String.valueOf(nString.charAt(nString.length() - i - 1)));
}
return answer;
}
}
charAt()을 사용하려고 형변환을 여러 번 했더니 코드가 좀 길어졌다.
class Solution {
public int[] solution(long n) {
String a = "" + n;
int[] answer = new int[a.length()];
int cnt=0;
while(n > 0) {
answer[cnt] = (int)(n % 10);
n /= 10;
cnt++;
}
return answer;
}
}
import java.util.stream.IntStream;
class Solution {
public int[] solution(long n) {
return new StringBuilder().append(n).reverse().chars().map(Character::getNumericValue).toArray();
}
}