1단계.
두 정수 A와 B가 주어졌을 때, A와 B를 비교하는 프로그램을 작성하시오.
첫째 줄에 다음 세 가지 중 하나를 출력한다.
A가 B보다 큰 경우에는 '>'를 출력한다.
A가 B보다 작은 경우에는 '<'를 출력한다.
A와 B가 같은 경우에는 '=='를 출력한다.
답: a, b = map(int, input().split())
if (a > b) :
print('>')
elif (a < b) :
print('<')
else :
print('==')
if문을 쓰면 된다. 파이썬에서는 else if 를 elif로 줄여 쓰며 조건을 쓰고 ":"을 넣어준다. 이후 그냥 코드 작성해 주면 된다.
2단계.
문제시험 점수를 입력받아 90 ~ 100점은 A, 80 ~ 89점은 B, 70 ~ 79점은 C, 60 ~ 69점은 D, 나머지 점수는 F를 출력하는 프로그램을 작성하시오.
답: a = int(input())
if (a >= 90):
print("A")
elif (a >= 80):
print("B")
elif (a >= 70):
print("C")
elif (a >= 60):
print("D")
else:
print("F")
1번 문제와 원리가 똑같다.
3단계.
연도가 주어졌을 때, 윤년이면 1, 아니면 0을 출력하는 프로그램을 작성하시오.
윤년은 연도가 4의 배수이면서, 100의 배수가 아닐 때 또는 400의 배수일 때이다.
예를 들어, 2012년은 4의 배수이면서 100의 배수가 아니라서 윤년이다. 1900년은 100의 배수이고 400의 배수는 아니기 때문에 윤년이 아니다. 하지만, 2000년은 400의 배수이기 때문에 윤년이다.
답: year = int(input())
if ((year%4 == 0)and(year%100 != 0)) or (year%400 == 0):
print('1')
else:
print('0')
4의 배수라면 나누었을 때 나머지가 0이면 된다. (100의 배수, 400의 배수도 마찬가지) ~이면서는 or 이고 "또는"은 and이다. 이를 기반으로 if문을 작성하면 된다.
4단계.
예를 들어, 좌표가 (12, 5)인 점 A는 x좌표와 y좌표가 모두 양수이므로 제1사분면에 속한다. 점 B는 x좌표가 음수이고 y좌표가 양수이므로 제2사분면에 속한다.
점의 좌표를 입력받아 그 점이 어느 사분면에 속하는지 알아내는 프로그램을 작성하시오. 단, x좌표와 y좌표는 모두 양수나 음수라고 가정한다.
답: x = int(input())
y = int(input())
if (x > 0 and y > 0) :
print(1)
elif (x < 0 and y > 0) :
print(2)
elif (x < 0 and y < 0) :
print(3)
elif (x > 0 and y < 0) :
print(4)
5단계.
상근이는 매일 아침 알람을 듣고 일어난다. 알람을 듣고 바로 일어나면 다행이겠지만, 항상 조금만 더 자려는 마음 때문에 매일 학교를 지각하고 있다.
상근이는 모든 방법을 동원해 보았지만, 조금만 더 자려는 마음은 그 어떤 것도 없앨 수가 없었다.
이런 상근이를 불쌍하게 보던 창영이는 자신이 사용하는 방법을 추천해 주었다.
바로 "45분 일찍 알람 설정하기"이다.
이 방법은 단순하다. 원래 설정되어 있는 알람을 45분 앞서는 시간으로 바꾸는 것이다. 어차피 알람 소리를 들으면, 알람을 끄고 조금 더 잘 것이기 때문이다. 이 방법을 사용하면, 매일 아침 더 잤다는 기분을 느낄 수 있고, 학교도 지각하지 않게 된다.
현재 상근이가 설정한 알람 시각이 주어졌을 때, 창영이의 방법을 사용한다면, 이를 언제로 고쳐야 하는지 구하는 프로그램을 작성하시오.
첫째 줄에 두 정수 H와 M이 주어진다. (0 ≤ H ≤ 23, 0 ≤ M ≤ 59) 그리고 이것은 현재 상근이가 설정한 알람 시간 H시 M분을 의미한다.
입력 시간은 24시간 표현을 사용한다. 24시간 표현에서 하루의 시작은 0:0(자정)이고, 끝은 23:59(다음날 자정 1분 전)이다. 시간을 나타낼 때, 불필요한 0은 사용하지 않는다.
답: H, M = map(int, input().split())
if (M < 45) : # 분단위가 45분보다 작을 때
if (H == 0) : # 0 시이면
H = 23
M += 60
else : # 0시가 아니면 (0시보다 크면)
H -= 1
M += 60
print(H, M-45)
키포인트는 먼저 "분"이 45분 미만인가 아닌가를 생각하는 것이다. 45분 이상이라면 무슨 시간이 되든 상관없이 M-45를 하면 된다. 만일 45분 미만이라면 "0시"가 키포인트가 된다. "0시"라면 H가 23시로 설정 M은 60을 더하면 된다. "0시"가 아니라면 시간에서 1을 빼고 M은 60을 더하면 된다. (1시간 = 60분)
6단계.
KOI 전자에서는 건강에 좋고 맛있는 훈제오리구이 요리를 간편하게 만드는 인공지능 오븐을 개발하려고 한다. 인공지능 오븐을 사용하는 방법은 적당한 양의 오리 훈제 재료를 인공지능 오븐에 넣으면 된다. 그러면 인공지능 오븐은 오븐구이가 끝나는 시간을 분 단위로 자동적으로 계산한다.
또한, KOI 전자의 인공지능 오븐 앞면에는 사용자에게 훈제오리구이 요리가 끝나는 시각을 알려 주는 디지털시계가 있다.
훈제오리구이를 시작하는 시각과 오븐구이를 하는 데 필요한 시간이 분단위로 주어졌을 때, 오븐구이가 끝나는 시각을 계산하는 프로그램을 작성하시오.
첫째 줄에는 현재 시각이 나온다. 현재 시각은 시 A (0 ≤ A ≤ 23)와 분 B (0 ≤ B ≤ 59)가 정수로 빈칸을 사이에 두고 순서대로 주어진다. 두 번째 줄에는 요리하는 데 필요한 시간 C (0 ≤ C ≤ 1,000)가 분 단위로 주어진다.
답: H, M = map(int, input().split())
timer = int(input())
H += timer // 60
M += timer % 60
if (M >= 60) :
H += 1
M -= 60
if (H >= 24) :
H -= 24
print(H,M)
시간, 분을 첫 줄에 받고 그다음 필요한 시간을 입력받는다.
이후 필요한 시간을 나눈 몫을 시간에 더하고 필요한 시간을 나눈 나머지를 분에 더한다. (이 부분이 어려웠다.)
나머지는 부분은 5단계랑 비슷하다.
7단계.
1에서부터 6까지의 눈을 가진 3개의 주사위를 던져서 다음과 같은 규칙에 따라 상금을 받는 게임이 있다.
같은 눈이 3개가 나오면 10,000원+(같은 눈) ×1,000원의 상금을 받게 된다. 같은 눈이 2개만 나오는 경우에는 1,000원+(같은 눈) ×100원의 상금을 받게 된다.모두 다른 눈이 나오는 경우에는 (그 중 가장 큰 눈)×100원의 상금을 받게 된다.
예를 들어, 3개의 눈 3, 3, 6이 주어지면 상금은 1,000+3 ×100으로 계산되어 1,300원을 받게 된다. 또 3개의 눈이 2, 2, 2로 주어지면 10,000+2 ×1,000으로 계산되어 12,000원을 받게 된다. 3개의 눈이 6, 2, 5로 주어지면 그중 가장 큰 값이 6이므로 6 ×100으로 계산되어 600원을 상금으로 받게 된다.
3개 주사위의 나온 눈이 주어질 때, 상금을 계산하는 프로그램을 작성하시오.
답:
a, b, c = map(int, input().split())
if (a == b == c) :
print(10000 + a * 1000)
elif (a == b) :
print(1000 + a * 100)
elif (a == c) :
print(1000 + c * 100)
elif (b == c) :
print(1000 + b * 100)
elif (a != b != c) :
if (a > b and a > c) :
print(a * 100)
if (b > a and b > c) :
print(b * 100)
if (c > a and c > b) :
print(c * 100)
뭔가 뭔가 복잡해 보이지만 천천히 위부터 따라가면 무슨 뜻인지 알 수 있다.
조건문을 더 효율적으로 쓰는 방법이 무엇일까?
어떤 로직으로 생각해야 시간, 공간 복잡도가 낮게 나올까?
'백준 (코테)' 카테고리의 다른 글
1~4단계 백준 복습 (0) | 2024.08.12 |
---|---|
4. [4단계] 제목: 1차원 배열 (0) | 2024.08.10 |
3. [3단계] 제목: 반복문 (1) | 2024.08.09 |
1. [1단계] 제목: 입출력과 사칙연산 (0) | 2024.08.07 |
0. 백준 방향성 잡기 (0) | 2024.08.06 |