일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 |
- pandas #folium #groupby #네이버부스트코스 #코칭스터디
- docker #cuda #docker container #도커 #도커 컨테이너 #쿠다 #cuda 11.3
- 구름자연어처리과정
- GPU #jtorch GPU #파이토치 병렬 #파이토치 GPU #pytorch gpu #multi process torch #horovod
- GPU #cuda out of memory #gpu 메모리 #pytorch
- ssh #우분투 ssh #우분터 서버 #도커 #우분투 도커 #docker #cuda #우분투 개발환경 #딥러닝 #ubuntu docker #ubuntu cuda
- 구름
- 머신러닝
- jupyter notebook #anaconda #vscode #pytorch #딥러닝 #deep learning #vscode server #서버 vscode #ssh vscode #vscode cuda
- BERT #구글BERT #BERT의정석
- 깃허브 #우분투 #ubuntu #Github #깃허브 우분투 #깃헙 우분투 #깃헙
- 파이썬 #Python
- cuda #centos #cuda삭제 #리눅스 #cenos cuda삭제
- docker #도커 #도커 컨테이너 #docker container #도커 우분투
- Machine Learning
- docker #우분투 #ubuntu #도커 설치 #docker 설치 #docker installation #우분투 도커
- 백준 #알고리즘 #골드
- docker #아나콘다 #anaconda #ubuntu anaconda #docker anaconda
- logistic regression
- pytorch #cuda #우분투 torch #ubuntu pytorch #cuda torch #cuda pytorch
- 알고리즘 #levenshtein distance #편집거리 #edit distance
- 백준
- 트랜스포머 #자연어처리 #딥러닝 #구글 #attention #self-attention #BERT #transformer #deeplearing
- 트랜스포머 #transformer #attention #self-attention #어텐션 #인공지능 #AI #딥러닝 #NLP #자연어처리
- Today
- Total
바닥부터 시작하는 개발 공부
[알고리즘]백준 1072: 게임 본문
알고리즘: 이분탐색
문제
김형택은 지금 몰래 Spider Solitaire(스파이더 카드놀이)를 하고 있다. 형택이는 이 게임을 이길 때도 있었지만, 질 때도 있었다. 누군가의 시선이 느껴진 형택이는 게임을 중단하고 코딩을 하기 시작했다. 의심을 피했다고 생각한 형택이는 다시 게임을 켰다. 그 때 형택이는 잠시 코딩을 하는 사이에 자신의 게임 실력이 눈에 띄게 향상된 것을 알았다.
이제 형택이는 앞으로의 모든 게임에서 지지 않는다. 하지만, 형택이는 게임 기록을 삭제 할 수 없기 때문에, 자신의 못하던 예전 기록이 현재 자신의 엄청난 실력을 증명하지 못한다고 생각했다.
게임 기록은 다음과 같이 생겼다.
- 게임 횟수 : X
- 이긴 게임 : Y (Z%)
- Z는 형택이의 승률이고, 소수점은 버린다. 예를 들어, X=53, Y=47이라면, Z=88이다.
X와 Y가 주어졌을 때, 형택이가 게임을 최소 몇 번 더 해야 Z가 변하는지 구하는 프로그램을 작성하시오.
입력
각 줄에 정수 X와 Y가 주어진다.
출력
첫째 줄에 형택이가 게임을 최소 몇 판 더 해야하는지 출력한다. 만약 Z가 절대 변하지 않는다면 -1을 출력한다.
제한
- 1 ≤ X ≤ 1,000,000,000
- 0 ≤ Y ≤ X
풀이
원래는 이분탐색 문제인데 조금 다른 방식으로 풀이해보았습니다
탐색을 진행할때 1스텝씩 이동을 하게 되면 당연하게도 시간초과에 걸립니다
이런식으로 전체 탐색을 진행해야하는 경우 그냥 과감하게 100스텝 혹은 1000스텝 정도 이동을 하면서
확인을 진행합니다
이 문제 같은 경우에는 첫번째 반복문의 경우 정수부가 초기 백분율의 정수부와 달라지는 경우
반복문을 탈출하는데 두번째 반복문을 이용해 다시 스텝을 거꾸로 밟아가줍니다
1스텝씩 이동하는 경우 시간이 N이라면 N/step크기 +step크기로 문제 해결이 가능합니다
import sys
from math import floor
X, Y = map(int, sys.stdin.readline().strip().split())
start = int((100*Y)/X)
cnt= 0
if int((100*Y)/X)<99:
while True:
X= X+100
Y= Y+100
cnt+=100
if start!=int((100*Y)/X):
break
while True:
X= X-1
Y= Y-1
cnt-=1
if start==int((100*Y)/X):
break
print(cnt+1)
else:
print(-1)
'Algorithm > 백준' 카테고리의 다른 글
[알고리즘]백준 15650: N과 M(2) (0) | 2023.02.24 |
---|---|
[알고리즘]백준 15649: N과 M(1) (0) | 2023.02.24 |
[알고리즘]백준 1735: 분수합 (0) | 2023.02.24 |
[알고리즘]백준 9613: GCD합 (1) | 2023.02.24 |
[알고리즘]백준 1235 : 학생 번호 (0) | 2023.02.24 |