Notice
Recent Posts
Recent Comments
Link
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 |
Tags
- 코딩테스트
- 인텔리제이
- Array.asList
- 11659
- 스택
- String.valueOf()
- Spring Web MVC
- 싱글톤패턴
- 코드스테이츠
- 알고리즘
- List.of
- 자바
- 성능테스트툴
- OOP
- 클라우드에서 도커 실행하기
- 재귀함수
- 프로그래머스
- java
- 백준
- 투포인터알고리즘
- Spring MVC 구성요소
- 버블정렬
- 재귀와반복문
- vm인스턴스생성
- Spring MVC 동작원리
- GCP
- 코드스테이츠 백엔드
- 구간합구하기
- 백준 11659
- MySQL
Archives
- Today
- Total
순간을 기록으로
[Java] 이진수 출력 | 인프런 | 재귀 본문
문제
10진수 N이 입력되면 2진수로 변환하여 출력하는 프로그램을 작성하세요. 단 재귀함수를 이용해야 합니다.
풀이
십진수를 이진수로 바꾸는 방법은 N을 2로 계속나누면서 몫과 나머지를 구하면 됩니다. 그리고 몫이 0이 될 때 구했던 나머지를 역순으로 붙이면 구하는 이진수가 나오게 됩니다.
위의 십진수 69를 계속 나눕니다. 그리고 몫이 0이 되면 지금까지 구한 이진수를 역순으로 이어붙입니다.
따라서 십진수 69의 이진수는 1000101이 됩니다.
이번 문제도 재귀함수를 이용하기 때문이 if-else 구조를 이용해서 문제를 풀겠습니다.
package 인프런.재귀와트리와그래프.이진수출력.방법1;
import java.util.Scanner;
public class Main {
static StringBuilder sb = new StringBuilder();
public void recursive(int n) {
if (n == 0) { // 몫이 0이라면
return;
}
else {
recursive(n/2);
sb.append(n % 2); // 이어 붙이기
}
}
public static void main(String[] args) {
Main T = new Main();
Scanner in = new Scanner(System.in);
int n = in.nextInt();
T.recursive(n);
System.out.println(sb.toString());
}
}
'Problem Solving' 카테고리의 다른 글
[Java] 피보나치 수열 출력하기 | 인프런 | 단순 재귀 와 메모이제이션 방식 (0) | 2022.04.21 |
---|---|
[Java] 팩토리얼 값 구하기 | 인프런 | 재귀 (0) | 2022.04.21 |
[Java] 재귀함수 | 인프런 | 재귀문제 (0) | 2022.04.21 |
[MySQL] Chemistry and Physics last | SQLZOO (0) | 2022.04.21 |
[MySQL] 문자열 안에 '(single quote) 있을 때 탈출하는 법 (0) | 2022.04.21 |
Comments