728x90
반응형
문제 설명
자연수 n이 매개변수로 주어집니다. n을 3진법 상에서 앞뒤로 뒤집은 후, 이를 다시 10진법으로 표현한 수를 return 하도록 solution 함수를 완성해주세요.
제한사항
- n은 1 이상 100,000,000 이하인 자연수입니다.
입출력 예nresult
45 | 7 |
125 | 229 |
입출력 예 설명
입출력 예 #1
- 답을 도출하는 과정은 다음과 같습니다.
45 | 1200 | 0021 | 7 |
- 따라서 7을 return 해야 합니다.
입출력 예 #2
- 답을 도출하는 과정은 다음과 같습니다.
125 | 11122 | 22111 | 229 |
- 따라서 229를 return 해야 합니다.
https://programmers.co.kr/learn/courses/30/lessons/68935
코딩테스트 연습 - 3진법 뒤집기
자연수 n이 매개변수로 주어집니다. n을 3진법 상에서 앞뒤로 뒤집은 후, 이를 다시 10진법으로 표현한 수를 return 하도록 solution 함수를 완성해주세요. 제한사항 n은 1 이상 100,000,000 이하인 자연수
programmers.co.kr
★소스코드★
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
|
import java.util.*;
class Solution {
public int solution(int n) {
int answer = 0;
ArrayList<Integer> revTNList = new ArrayList<Integer>();
while(n!=0){
revTNList.add(n%3);
n /= 3;
}
for(int i=0; i<revTNList.size(); i++)
answer += revTNList.get(revTNList.size() - 1 - i) * Math.pow(3, i);
return answer;
}
}
|
cs |
★정리★
10진법의 수를 3진법으로 만들고 뒤집은 3진법 수를 다시 10진법의 수로 출력하는 문제.
ArrayList에 나머지 값을 넣고 for문을 이용하여 끝에 있는 인덱스부터 연산하여answer에 값을 누적시키며 10진수로 변환
728x90
반응형
'알고리즘' 카테고리의 다른 글
Java - 프로그래머스 : 두 개 뽑아서 더하기 (0) | 2022.03.13 |
---|---|
Java - 프로그래머스 : 예산 (0) | 2022.03.13 |
Java - 프로그래머스 : 약수의 개수와 덧셈 (0) | 2022.03.13 |
Java - 프로그래머스 : 실패율 (0) | 2022.03.08 |
Java - 프로그래머스 : 폰켓몬 (0) | 2022.01.27 |