문제풀이/백준(Boj) 문제풀이

문제풀이/백준(Boj) 단계별 풀이백준 - 단계별로 풀기 8단계 파이썬 - (기본 수학1 단계 - 1712번, 2292번, 1193번,2869번, 10250번, 2775번, 2839번, 10757번, 1011번)

얄루몬 2021. 7. 17. 23:16

https://www.acmicpc.net/problem/1712

 

1712번: 손익분기점

월드전자는 노트북을 제조하고 판매하는 회사이다. 노트북 판매 대수에 상관없이 매년 임대료, 재산세, 보험료, 급여 등 A만원의 고정 비용이 들며, 한 대의 노트북을 생산하는 데에는 재료비와

www.acmicpc.net

손익분기점

시간 제한메모리 제한제출정답맞은 사람정답 비율

0.35 초 128 MB 117942 28669 24860 24.518%

문제

월드전자는 노트북을 제조하고 판매하는 회사이다. 노트북 판매 대수에 상관없이 매년 임대료, 재산세, 보험료, 급여 등 A만원의 고정 비용이 들며, 한 대의 노트북을 생산하는 데에는 재료비와 인건비 등 총 B만원의 가변 비용이 든다고 한다.

예를 들어 A=1,000, B=70이라고 하자. 이 경우 노트북을 한 대 생산하는 데는 총 1,070만원이 들며, 열 대 생산하는 데는 총 1,700만원이 든다.

노트북 가격이 C만원으로 책정되었다고 한다. 일반적으로 생산 대수를 늘려 가다 보면 어느 순간 총 수입(판매비용)이 총 비용(=고정비용+가변비용)보다 많아지게 된다. 최초로 총 수입이 총 비용보다 많아져 이익이 발생하는 지점을 손익분기점(BREAK-EVEN POINT)이라고 한다.

A, B, C가 주어졌을 때, 손익분기점을 구하는 프로그램을 작성하시오.

입력

첫째 줄에 A, B, C가 빈 칸을 사이에 두고 순서대로 주어진다. A, B, C는 21억 이하의 자연수이다.

출력

첫 번째 줄에 손익분기점 즉 최초로 이익이 발생하는 판매량을 출력한다. 손익분기점이 존재하지 않으면 -1을 출력한다.

예제 입력 1 복사

1000 70 170

예제 출력 1 복사

11

예제 입력 2 복사

3 2 1

예제 출력 2 복사

-1

예제 입력 3 복사

2100000000 9 10

예제 출력 3 복사

2100000001

노트

이 문제에서 설명하는 손익분기점은 회계학에서 정의하는 손익분기점과 다를 수 있다.

a, b, c = map(int,input().split())

if b >= c:
    print(-1)

else :
    print(a//(c-b)+1)

👽해설👽

- 파려는 물건의 값보다 나가는 가변비용이 더 클 때 손익분기점이 없다 따라서 b(가변비용)가 c(상품가격)보다 클 때 -1 즉, 손익분기점이 없는 경우를 나타낸다.

- a+b*n <= c*n 일 때, 손익분기점을 넘기는 상황이고 b = a%c-b 는 실수형으로 손익분기점을 보여주기 때문에 몫을 구하는 연산자 //를 써서 표현한다.

- +1을 해주는 이유는 0이 포함되기 때문인데, 예를 들어 고정비용 A가 10 가변비용이 70 상품가격이 80일 때 1대를 팔면 총 0원이 되고 2대를 팔기 시작한 시점부터 +10으로 손익분기점을 넘기는 것이기 때문에 +1을 해준다! 


https://www.acmicpc.net/problem/2292

 

2292번: 벌집

위의 그림과 같이 육각형으로 이루어진 벌집이 있다. 그림에서 보는 바와 같이 중앙의 방 1부터 시작해서 이웃하는 방에 돌아가면서 1씩 증가하는 번호를 주소로 매길 수 있다. 숫자 N이 주어졌

www.acmicpc.net

벌집 출처

시간 제한메모리 제한제출정답맞은 사람정답 비율

2 초 128 MB 68811 31145 26913 45.398%

문제

위의 그림과 같이 육각형으로 이루어진 벌집이 있다. 그림에서 보는 바와 같이 중앙의 방 1부터 시작해서 이웃하는 방에 돌아가면서 1씩 증가하는 번호를 주소로 매길 수 있다. 숫자 N이 주어졌을 때, 벌집의 중앙 1에서 N번 방까지 최소 개수의 방을 지나서 갈 때 몇 개의 방을 지나가는지(시작과 끝을 포함하여)를 계산하는 프로그램을 작성하시오. 예를 들면, 13까지는 3개, 58까지는 5개를 지난다.

입력

첫째 줄에 N(1 ≤ N ≤ 1,000,000,000)이 주어진다.

출력

입력으로 주어진 방까지 최소 개수의 방을 지나서 갈 때 몇 개의 방을 지나는지 출력한다.

예제 입력 1 복사

13

예제 출력 1 복사

3

출처

ICPC > Regionals > Asia Pacific > Korea > Nationwide Internet Competition > Seoul Nationalwide Internet Competition 2004 B번

  • 문제의 오타를 찾은 사람: waylight3

알고리즘 분류

 

기본적인 구조 이해. 

1칸(1번째) / (1) -> 6칸(2번째) / (2~7) -> 12칸(3번째) / (8~19)  -> 18칸(4번째) / (20 ~ 37) -> 24칸(5번째) (38 ~ 61) -> 30칸(6번째) / (62 ~ 101)

 

<오답>

N = int(input())

room = (N//6) +1
print(room)

- 처음엔 간단하게 입력받은 값을 6으로 나눈 몫에 +1을 해주면 되겠구나 했지만 생각해보니 2번째만 6개로 늘어나도 다음부턴 12 18 24 6의 배수로 늘어나는 것을 고려하지 않았다 ㅋ 그래서 다시 그걸 고려해서 코드를 구현 했다.


N = int(input())

cnt = 1

while N > 1: #1이 입력되는 경우는 어차피 바로 print 해주기 때문에 따로 구하지 않음.
    N -= (6*cnt) #6의 배수를 빼며 구해준다.N이 1이 될때까지.
    cnt += 1
print(cnt)

https://www.acmicpc.net/problem/1193

 

1193번: 분수찾기

첫째 줄에 X(1 ≤ X ≤ 10,000,000)가 주어진다.

www.acmicpc.net

분수찾기

시간 제한메모리 제한제출정답맞은 사람정답 비율

0.5 초 (추가 시간 없음) 256 MB 50454 24422 21466 51.118%

문제

무한히 큰 배열에 다음과 같이 분수들이 적혀있다.

1/1 1/2 1/3 1/4 1/5
2/1 2/2 2/3 2/4
3/1 3/2 3/3
4/1 4/2
5/1

이와 같이 나열된 분수들을 1/1 -> 1/2 -> 2/1 -> 3/1 -> 2/2 -> … 과 같은 지그재그 순서로 차례대로 1번, 2번, 3번, 4번, 5번, … 분수라고 하자.

X가 주어졌을 때, X번째 분수를 구하는 프로그램을 작성하시오.

입력

첫째 줄에 X(1 ≤ X ≤ 10,000,000)가 주어진다.

출력

첫째 줄에 분수를 출력한다.

예제 입력 1 복사

14

예제 출력 1 복사

2/4

 

 

1/1 (1) 1/2 (2) 1/3 (7) 1/4 (13) 1/5
2/1 (3) 2/2 (5) 2/3 (8) 2/4 (14)
3/1 (4) 3/2 (6) 3/3 (11)
4/1 (9) 4/2 (10) … (12)
5/1

#1193

x = int(input())
line = 1

while x > line: # x = 5 
    x -= line # 5, 4, 2 
    line += 1 # 1, 2, 3

if line % 2 ==0 :
    a = x
    b = line - x + 1
else:
    a = line - x + 1
    b = x
print(a,"/",b, sep='')

1/1 -> 1 (line)

1/2, 2/1 -> 2(line)

.

.

.


https://www.acmicpc.net/problem/2869

 

2869번: 달팽이는 올라가고 싶다

첫째 줄에 세 정수 A, B, V가 공백으로 구분되어서 주어진다. (1 ≤ B < A ≤ V ≤ 1,000,000,000)

www.acmicpc.net

달팽이는 올라가고 싶다 출처다국어

한국어   

시간 제한메모리 제한제출정답맞은 사람정답 비율

0.15 초 (추가 시간 없음) (하단 참고) 128 MB 98518 25770 21768 27.694%

문제

땅 위에 달팽이가 있다. 이 달팽이는 높이가 V미터인 나무 막대를 올라갈 것이다.

달팽이는 낮에 A미터 올라갈 수 있다. 하지만, 밤에 잠을 자는 동안 B미터 미끄러진다. 또, 정상에 올라간 후에는 미끄러지지 않는다.

달팽이가 나무 막대를 모두 올라가려면, 며칠이 걸리는지 구하는 프로그램을 작성하시오.

입력

첫째 줄에 세 정수 A, B, V가 공백으로 구분되어서 주어진다. (1 ≤ B < A ≤ V ≤ 1,000,000,000)

출력

첫째 줄에 달팽이가 나무 막대를 모두 올라가는데 며칠이 걸리는지 출력한다.

예제 입력 1 복사

2 1 5

예제 출력 1 복사

4

예제 입력 2 복사

5 1 6

예제 출력 2 복사

2

예제 입력 3 복사

100 99 1000000000

예제 출력 3 복사

999999901

 

<오답>

a, b, v = map(int,input().split())

N = v//(a-b)

if a<b:
    ("달팽이가 올라가는 것보다 떨어지는게 많아서 못가요~")
else:
    print(N)

- 간단하게 N을 구해주면 되는 문제라고 생각했는데.. 진짜 N만 구해짐 . 그래서 정답이 다 다르게 나온다.

a, b, v = map(int,input().split())


day =0 

for i in range(1,v):
    if a > b:
        v -= (a*i - b*i)
        day += 1

    else:
        print("달팽이가 올라가는 것보다 미끄러지는 게 더 커서 못가요~")
        break
    
print(day)

- 이 역시도 계속 진행돼서 오답

a, b, v = map(int,input().split())
day = 0 

while True:
    day += 0
    if (a*day) - (b*day) >= v:
        break
print(day)

- 시간 초과 반복문 없이 바로 대입으로 식을 풀어야 한다.

 


 

a, b, v = map(int,input().split())
day = 0 

if (v-b) % (a-b) !=0:
    day = ((v-b)//(a-b)) +1
else:
    day = ((v-b)//(a-b))

print(day)

👽해설👽

- 반복문을 쓰면 시간초과로 인해서 n = v/(a-b) 가 쓰일 수 없기에 다른 식을 생각해야 한다.

- 여기서 주의해야 할 점은 정상에 도착해서는 미끄러지지 않는 다는 것! 

- 나머지가 0이 아닌 경우엔 하루가 더 필요하기 때문에 +1을 해준다.

- 나머지가 0인 경우엔 몫을 출력해주면 된다. 

 


https://www.acmicpc.net/problem/10250

 

10250번: ACM 호텔

프로그램은 표준 입력에서 입력 데이터를 받는다. 프로그램의 입력은 T 개의 테스트 데이터로 이루어져 있는데 T 는 입력의 맨 첫 줄에 주어진다. 각 테스트 데이터는 한 행으로서 H, W, N, 세 정수

www.acmicpc.net

ACM 호텔 출처다국어

한국어   

시간 제한메모리 제한제출정답맞은 사람정답 비율

1 초 256 MB 75531 26325 22458 34.191%

문제

ACM 호텔 매니저 지우는 손님이 도착하는 대로 빈 방을 배정하고 있다. 고객 설문조사에 따르면 손님들은 호텔 정문으로부터 걸어서 가장 짧은 거리에 있는 방을 선호한다고 한다. 여러분은 지우를 도와 줄 프로그램을 작성하고자 한다. 즉 설문조사 결과 대로 호텔 정문으로부터 걷는 거리가 가장 짧도록 방을 배정하는 프로그램을 작성하고자 한다.

문제를 단순화하기 위해서 호텔은 직사각형 모양이라고 가정하자. 각 층에 W 개의 방이 있는 H 층 건물이라고 가정하자 (1 ≤ H, W ≤ 99). 그리고 엘리베이터는 가장 왼쪽에 있다고 가정하자(그림 1 참고). 이런 형태의 호텔을 H × W 형태 호텔이라고 부른다. 호텔 정문은 일층 엘리베이터 바로 앞에 있는데, 정문에서 엘리베이터까지의 거리는 무시한다. 또 모든 인접한 두 방 사이의 거리는 같은 거리(거리 1)라고 가정하고 호텔의 정면 쪽에만 방이 있다고 가정한다.

그림 1. H = 6 이고 W = 12 인 H × W 호텔을 간략하게 나타낸 그림

방 번호는 YXX 나 YYXX 형태인데 여기서 Y 나 YY 는 층 수를 나타내고 XX 는 엘리베이터에서부터 세었을 때의 번호를 나타낸다. 즉, 그림 1 에서 빗금으로 표시한 방은 305 호가 된다.

손님은 엘리베이터를 타고 이동하는 거리는 신경 쓰지 않는다. 다만 걷는 거리가 같을 때에는 아래층의 방을 더 선호한다. 예를 들면 102 호 방보다는 301 호 방을 더 선호하는데, 102 호는 거리 2 만큼 걸어야 하지만 301 호는 거리 1 만큼만 걸으면 되기 때문이다. 같은 이유로 102 호보다 2101 호를 더 선호한다.

여러분이 작성할 프로그램은 초기에 모든 방이 비어있다고 가정하에 이 정책에 따라 N 번째로 도착한 손님에게 배정될 방 번호를 계산하는 프로그램이다. 첫 번째 손님은 101 호, 두 번째 손님은 201 호 등과 같이 배정한다. 그림 1 의 경우를 예로 들면, H = 6이므로 10 번째 손님은 402 호에 배정해야 한다.

입력

프로그램은 표준 입력에서 입력 데이터를 받는다. 프로그램의 입력은 T 개의 테스트 데이터로 이루어져 있는데 T 는 입력의 맨 첫 줄에 주어진다. 각 테스트 데이터는 한 행으로서 H, W, N, 세 정수를 포함하고 있으며 각각 호텔의 층 수, 각 층의 방 수, 몇 번째 손님인지를 나타낸다(1 ≤ H, W ≤ 99, 1 ≤ N ≤ H × W). 

출력

프로그램은 표준 출력에 출력한다. 각 테스트 데이터마다 정확히 한 행을 출력하는데, 내용은 N 번째 손님에게 배정되어야 하는 방 번호를 출력한다.

예제 입력 1 복사

2

6 12 10

30 50 72

예제 출력 1 복사

402
1203

 

<오답>

#10250

t = int(input())


for i in range(t):
    h,w,n = map(int,input().split())
    floor = n%h
    roomnumber = (n//h)+1
    if h <10:
        print(floor,"0",roomnumber)
    else:
        print(floor,roomnumber)
>>>
2
6 12 10
4 0 2 
>>>
2
30 50 72
12 3
#10250

t = int(input())


for i in range(t):
    h,w,n = map(int,input().split())
    floor = n%h
    roomnumber = (n//h)+1
    print(floor,"0",roomnumber,sep='')
2
30 50 72
1203

2
6 12 10
402

- if문이 필요하지 않음을 알고 코드를 수정했지만 정답은 제대로 나오지만 로직이 제대로 된 것이 아닌갑다.. 틀렸습니다가 또 뜬다 ㅎ.. 쩝

#10250

t = int(input())

for i in range(t):
    h,w,n = map(int,input().split())
    f = (n%h) *100
    no = (n//h)+1

    if f == 0:
        no -= 1

    print(f+no)

#10250

t = int(input())

for i in range(t):
    h,w,n = map(int,input().split())
    f = 0 
    no = 0
    if n % h == 0:
        f = h * 100 # 6층건물에 6번째 입장이면 601호 배정이기에 6층을 표현하기 위해 600을 입력받아야 함
        no = n//h #몫이 1이 나오기 때문
    else:
        f = (n%h)*100
        no = n//h +1
    print(f+no)

👽해설👽

- 오답 천국에서 아예 방법을 틀어서 풀었다. floor와 roomnumber의 사이에 0을 넣어주는 개념이 아닌 f에 100을 곱해서 룸 넘버를 더해주는 방식으로 풀이를 바꿔서 풀었다.

- n % h == 0이 될 땐 층수가 0이 되면 안되기 때문에 이 부분을 if문을 넣어 설정해주었다.

- 그리고 나머지 n % h != 0이 아닐 경우를 또 설정해서 마지막 출력해주었다.

 

어떻게 고민했을까❓

우선적으로 기본 풀이는 어렵지 않던 문제였다. 

실제로 그림을 그려서 대입을 해보니 규칙이 어렵지 않게 나왔다.

그러나 쉽게 간 만큼 쉽게만 생각해서 ^^.. 마지막에 조금 막혔던 문제.

층수와 호수를 구하는 공식이 생각만큼 어렵지 않았지만 틀에 박힌 내 머리가 ..

큰 난관 ^^.. 유연한 자세로 문제를 풀길 바라본다..

 

공책을 한 권 펴놓고 .. 끄적이면 답이 보이느니라~....는 무슨


https://www.acmicpc.net/problem/2775

 

2775번: 부녀회장이 될테야

첫 번째 줄에 Test case의 수 T가 주어진다. 그리고 각각의 케이스마다 입력으로 첫 번째 줄에 정수 k, 두 번째 줄에 정수 n이 주어진다

www.acmicpc.net

부녀회장이 될테야

시간 제한메모리 제한제출정답맞은 사람정답 비율

1 초 128 MB 39439 22266 19305 57.565%

문제

평소 반상회에 참석하는 것을 좋아하는 주희는 이번 기회에 부녀회장이 되고 싶어 각 층의 사람들을 불러 모아 반상회를 주최하려고 한다.

이 아파트에 거주를 하려면 조건이 있는데, “a층의 b호에 살려면 자신의 아래(a-1)층의 1호부터 b호까지 사람들의 수의 합만큼 사람들을 데려와 살아야 한다” 는 계약 조항을 꼭 지키고 들어와야 한다.

아파트에 비어있는 집은 없고 모든 거주민들이 이 계약 조건을 지키고 왔다고 가정했을 때, 주어지는 양의 정수 k와 n에 대해 k층에 n호에는 몇 명이 살고 있는지 출력하라. 단, 아파트에는 0층부터 있고 각층에는 1호부터 있으며, 0층의 i호에는 i명이 산다.

입력

첫 번째 줄에 Test case의 수 T가 주어진다. 그리고 각각의 케이스마다 입력으로 첫 번째 줄에 정수 k, 두 번째 줄에 정수 n이 주어진다

출력

각각의 Test case에 대해서 해당 집에 거주민 수를 출력하라.

제한

  • 1 ≤ k, n ≤ 14

예제 입력 1 복사

2

 

1

3

 

2

3

예제 출력 1 복사

6

10

#2775

t = int(input())

for _ in range(t):
    k = int(input())
    n = int(input())
    
    p = [p for p in range(1,n+1)]
    
    for i in range(k):
        for j in range(1,n):
            p[j] += p[j-1]
    print(p[-1])

acmicpc.net/problem/2839

 

2839번: 설탕 배달

상근이는 요즘 설탕공장에서 설탕을 배달하고 있다. 상근이는 지금 사탕가게에 설탕을 정확하게 N킬로그램을 배달해야 한다. 설탕공장에서 만드는 설탕은 봉지에 담겨져 있다. 봉지는 3킬로그

www.acmicpc.net

설탕 배달 출처다국어

한국어   

시간 제한메모리 제한제출정답맞은 사람정답 비율

1 초 128 MB 170739 55266 43439 33.360%

문제

상근이는 요즘 설탕공장에서 설탕을 배달하고 있다. 상근이는 지금 사탕가게에 설탕을 정확하게 N킬로그램을 배달해야 한다. 설탕공장에서 만드는 설탕은 봉지에 담겨져 있다. 봉지는 3킬로그램 봉지와 5킬로그램 봉지가 있다.

상근이는 귀찮기 때문에, 최대한 적은 봉지를 들고 가려고 한다. 예를 들어, 18킬로그램 설탕을 배달해야 할 때, 3킬로그램 봉지 6개를 가져가도 되지만, 5킬로그램 3개와 3킬로그램 1개를 배달하면, 더 적은 개수의 봉지를 배달할 수 있다.

상근이가 설탕을 정확하게 N킬로그램 배달해야 할 때, 봉지 몇 개를 가져가면 되는지 그 수를 구하는 프로그램을 작성하시오.

입력

첫째 줄에 N이 주어진다. (3 ≤ N ≤ 5000)

출력

상근이가 배달하는 봉지의 최소 개수를 출력한다. 만약, 정확하게 N킬로그램을 만들 수 없다면 -1을 출력한다.

예제 입력 1 복사

18

예제 출력 1 복사

4

예제 입력 2 복사

4

예제 출력 2 복사

-1

예제 입력 3 복사

6

예제 출력 3 복사

2

예제 입력 4 복사

9

예제 출력 4 복사

3

예제 입력 5 복사

11

예제 출력 5 복사

3

<오답>

n = int(input())

a, b, lcm = 3, 5, 15
cnt = 0

if n % lcm == 0: #입력받은 수가 최소공배수인 경우 5로만 나눠도 됨
    cnt = n // b 
    print(cnt)
    
elif n % a == 0 and n % b != 0: #입력받은 수가 3의 배수일 땐 (최소공배수 제외.)
    cnt = n // a
    print(cnt)
elif n % a != 0 and n % b == 0:
    cnt = n // b
    print(cnt)
elif n % lcm == 3: #입력받은 수에서 최소공배수를 나눴을 때 나머지가 3이면 cnt =+1
    cnt = n // b+1
    print(cnt)
elif (n % a)%b==0: #3으로 나누고 남은 나머지가 5로 나눠질 때
    cnt = n//a
    n = n%a
    cnt += n//b
    print(cnt)
elif (n%b)%a==0: #5로 나누고 남은 나머지가 5로 나눠질 때 
    cnt = n//b
    n = n%b
    cnt += n//a
    print(cnt)
    
else:
	print(-1)

- 무작정 풀어댔는데.. 안 된다는 걸 깨닫고 빠르게 코드 수정을 했다 ㅋㅋ ..

- 아무래도 3으로 나눠서 5의 배수가 되는 경우를 위해서는 for문이나 while문이 필요할 듯 싶다.


n = int(input()) # 설탕

cnt = 0 # 봉지 수

while n >= 0:
    if n % 5 == 0: # 5로 나눈 나머지가 0인 경우
        cnt += n // 5 # 5로 나눈 몫 추력
        print(cnt)
        break
    n -= 3 # 입력받은 수를 3으로 계속 빼줘서 5의 배수가 될때까지 반복 5의 배수가 되면 if문을 통해서 
    cnt += 1 # 봉지에 개수 추가
else:
    print(-1) # while문이 거짓이 되면 -1 출력

https://www.acmicpc.net/problem/10757

 

10757번: 큰 수 A+B

두 정수 A와 B를 입력받은 다음, A+B를 출력하는 프로그램을 작성하시오.

www.acmicpc.net

큰 수 A+B

시간 제한메모리 제한제출정답맞은 사람정답 비율

1 초 256 MB 30002 13321 11545 48.637%

문제

두 정수 A와 B를 입력받은 다음, A+B를 출력하는 프로그램을 작성하시오.

입력

첫째 줄에 A와 B가 주어진다. (0 < A,B < 1010000)

출력

첫째 줄에 A+B를 출력한다.

예제 입력 1 복사

9223372036854775807 9223372036854775808

예제 출력 1 복사

18446744073709551615

출처

알고리즘 분류

 

A, B = map(int, input().split())
print(A+B)

- 다른 언어는 수가 너무 커서 오류가 난다고 한다. 

- 파이썬의 장점이 여기서 두각을 드러낸다. 


https://www.acmicpc.net/problem/1011

 

1011번: Fly me to the Alpha Centauri

우현이는 어린 시절, 지구 외의 다른 행성에서도 인류들이 살아갈 수 있는 미래가 오리라 믿었다. 그리고 그가 지구라는 세상에 발을 내려 놓은 지 23년이 지난 지금, 세계 최연소 ASNA 우주 비행

www.acmicpc.net

Fly me to the Alpha Centauri

시간 제한메모리 제한제출정답맞은 사람정답 비율

2 초 512 MB 61120 17501 13790 29.779%

문제

우현이는 어린 시절, 지구 외의 다른 행성에서도 인류들이 살아갈 수 있는 미래가 오리라 믿었다. 그리고 그가 지구라는 세상에 발을 내려 놓은 지 23년이 지난 지금, 세계 최연소 ASNA 우주 비행사가 되어 새로운 세계에 발을 내려 놓는 영광의 순간을 기다리고 있다.

그가 탑승하게 될 우주선은 Alpha Centauri라는 새로운 인류의 보금자리를 개척하기 위한 대규모 생활 유지 시스템을 탑재하고 있기 때문에, 그 크기와 질량이 엄청난 이유로 최신기술력을 총 동원하여 개발한 공간이동 장치를 탑재하였다. 하지만 이 공간이동 장치는 이동 거리를 급격하게 늘릴 경우 기계에 심각한 결함이 발생하는 단점이 있어서, 이전 작동시기에 k광년을 이동하였을 때는 k-1 , k 혹은 k+1 광년만을 다시 이동할 수 있다. 예를 들어, 이 장치를 처음 작동시킬 경우 -1 , 0 , 1 광년을 이론상 이동할 수 있으나 사실상 음수 혹은 0 거리만큼의 이동은 의미가 없으므로 1 광년을 이동할 수 있으며, 그 다음에는 0 , 1 , 2 광년을 이동할 수 있는 것이다. ( 여기서 다시 2광년을 이동한다면 다음 시기엔 1, 2, 3 광년을 이동할 수 있다. )

김우현은 공간이동 장치 작동시의 에너지 소모가 크다는 점을 잘 알고 있기 때문에 x지점에서 y지점을 향해 최소한의 작동 횟수로 이동하려 한다. 하지만 y지점에 도착해서도 공간 이동장치의 안전성을 위하여 y지점에 도착하기 바로 직전의 이동거리는 반드시 1광년으로 하려 한다.

김우현을 위해 x지점부터 정확히 y지점으로 이동하는데 필요한 공간 이동 장치 작동 횟수의 최솟값을 구하는 프로그램을 작성하라.

입력

입력의 첫 줄에는 테스트케이스의 개수 T가 주어진다. 각각의 테스트 케이스에 대해 현재 위치 x목표 위치 y 가 정수로 주어지며, x는 항상 y보다 작은 값을 갖는다. (0 ≤ x < y < 231)

출력

각 테스트 케이스에 대해 x지점으로부터 y지점까지 정확히 도달하는데 필요한 최소한의 공간이동 장치 작동 횟수를 출력한다.

예제 입력 1 복사

3

0 3

1 5

45 50

예제 출력 1 복사

3

3

4

출처

  • 문제를 번역한 사람: AIAI

알고리즘 분류

 

y-x (거리차이) 이동거리(구체) 처음과 마지막은 1로 고정 이동거리(번)
1 1 1번
2 1->1 2번
3 1->1->1 3번
4 1->2->1 3번
5 1->2->1->1 4번
6 1->2->2->1 4번
7 1->2->2->1->1 5번
8 1->2->2->2->1 5번
9 1->2->3->2->1 5번
10 1->2->3->2->1->1 6번
11 1->2->3->2->2->1 6번
12 1->2->3->3->2->1 6번
13 1->2->3->3->2->1->1 7번
14 1->2->3->3->2->2->1 7번
15 1->2->3->3->3->2->1 7번
16 1->2->3->4->3->2->1 7번
17 1->2->3->4->3->2->1->1 8번
t = int(input())
for i in range(t):
    a, b = map(int, input().split())
    c = b - a
    num = 1
    while True:
        if num ** 2 <= c < (num + 1) ** 2:
            break
        num += 1
        
    if num ** 2 == c:
        print((num * 2) - 1)
        
    elif num ** 2 < c <= num ** 2 + num:
        print(num * 2)
        
    else:
        print((num * 2) + 1)