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
- DP
- kotlin
- 자료구조
- back-end
- TDD
- 알고리즘
- 프로그래머스
- 코틀린
- BFS
- DFS
- Brute-force
- 모던자바
- lambda
- algorithm
- 운영체제
- backtracking
- OS
- programmers
- 자바
- 백트래킹
- Spring
- 네트워크
- LEVEL2
- 프로젝트
- Java8
- 백준
- java
- baekjoon
- 그래프
- 스프링
Archives
- Today
- Total
요깨비's LAB
[백준, BFS, Java] P.16953 A->B 본문
import java.util.Scanner;
public class Main {
static boolean isGet = false;
public static void main(String[] args) {
Scanner scr = new Scanner(System.in);
long A = scr.nextInt();
long B = scr.nextInt();
multiplyTwo(A, B, 1);
if (isGet) {
return;
}
appendOne(A, B, 1);
if (isGet) {
return;
}
System.out.println(-1);
}
public static void multiplyTwo(long value, long B, long count) {
if (isGet || value > B) {
return;
}
if (value == B) {
System.out.println(count);
isGet = true;
return;
}
value *= 2;
multiplyTwo(value, B, count + 1);
appendOne(value, B, count + 1);
}
public static void appendOne(long value, long B, long count) {
if (isGet || value > B) {
return;
}
if (value == B) {
System.out.println(count);
isGet = true;
return;
}
StringBuilder sb = new StringBuilder();
sb.append(value);
sb.append(1);
value = Long.parseLong(sb.toString());
multiplyTwo(value, B, count + 1);
appendOne(value, B, count + 1);
}
}
'알고리즘(Java) > BFS&DFS' 카테고리의 다른 글
[백준, BFS, Java] P.2146 다리 만들기 (0) | 2021.09.20 |
---|---|
[백준, BFS, Java] P.2638 치즈 (0) | 2021.08.31 |
[백준, DFS, JAVA] P11725. 트리의 부모 찾기 (0) | 2020.10.07 |
[백준, Graph, JAVA] P.11403 경로찾기 (0) | 2019.12.11 |
[백준, DFS, JAVA] P.2668 숫자 고르기 (0) | 2019.12.05 |
Comments