PS/백준

[백준] 25418 - 정수 a를 k로 만들기

2024. 1. 11. 17:32
 

25418번: 정수 a를 k로 만들기

7(A), 8(연산 1), 9(연산 1), 18(연산 2), 19(연산 1), 38(연산 2), 76(연산 2), 77(연산 1)이 최소 연산이므로 정답은 7이다.

www.acmicpc.net

✏️  풀이

입력으로 a, k가 주어지는데 그냥 a를 k로 만드는 최소 연산 횟수를 출력하는 것이다. 최소, 최단 이런 단어가 보이면 이제는 바로 BFS로 풀면 되겠다는 생각을 한다. 뭐 아닐 수 도 있겠지만, 그건 많이 풀어보면 BFS구나, 아니구나를 판단할 수 있을 것이라고 믿는다. 

 

큐에는 시작과 연산 횟수를 넣었다. 그렇게 연산을 하면 cnt를 증가 시키고, k에 도달하면 출력을 하고 끝을 낸다. BFS의 개념만 알면 금방 풀 수 있는 문제라서 쉽게 풀 수 있었다.

💻  코드

import sys; input = sys.stdin.readline
from collections import deque

start, dest = map(int, input().split())
q = deque([(start, 0)])
visited = set([start])
while q:
    cur, cnt = q.popleft()
    if cur == dest:
        print(cnt)
        break
    cnt += 1
    if cur*2 <= dest and cur*2 not in visited:
        q.append((cur*2, cnt))
        visited.add(cur*2)
    if cur+1 <= dest and cur+1 not in visited:
        q.append((cur+1, cnt))
        visited.add(cur+1)

'PS > 백준' 카테고리의 다른 글

[백준] 2589 - 보물섬  (0) 2024.04.13
[백준] 5430 - AC  (2) 2024.01.11
[백준] 2583 - 영역 구하기  (0) 2024.01.11
실버2 색종이 만들기(2630)  (1) 2024.01.01
실버1 z(1074)  (1) 2023.12.31
'PS/백준' 카테고리의 다른 글
  • [백준] 2589 - 보물섬
  • [백준] 5430 - AC
  • [백준] 2583 - 영역 구하기
  • 실버2 색종이 만들기(2630)
jjw000628
jjw000628
jjw000628
wldnd2
jjw000628
전체
오늘
어제
  • 분류 전체보기 (27)
    • Skill Up (1)
      • Algorithm Theory (1)
      • Java (0)
      • JS (0)
      • 프로젝트 및 회고 (0)
    • PS (23)
      • 백준 (15)
      • 프로그래머스 (8)
    • Lab (3)
      • Basic Concept (0)
      • 무선 이동 통신 (3)

블로그 메뉴

  • 홈
  • 태그
  • 방명록

공지사항

인기 글

태그

  • 브루트포스
  • 그래프
  • 네트워크
  • 파싱
  • Cpp
  • 깊이우선탐색
  • 재귀
  • 정규식
  • C++
  • JS
  • 누적합
  • 너비우선탐색
  • 프로그래머스
  • DP
  • 백준
  • 파이썬
  • dfs
  • 분할정복
  • 문자열
  • 알고리즘
  • BFS
  • 그래프탐색
  • 무선

최근 댓글

최근 글

hELLO · Designed By 정상우.
jjw000628
[백준] 25418 - 정수 a를 k로 만들기
상단으로

티스토리툴바

단축키

내 블로그

내 블로그 - 관리자 홈 전환
Q
Q
새 글 쓰기
W
W

블로그 게시글

글 수정 (권한 있는 경우)
E
E
댓글 영역으로 이동
C
C

모든 영역

이 페이지의 URL 복사
S
S
맨 위로 이동
T
T
티스토리 홈 이동
H
H
단축키 안내
Shift + /
⇧ + /

* 단축키는 한글/영문 대소문자로 이용 가능하며, 티스토리 기본 도메인에서만 동작합니다.