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

 

10818번: 최소, 최대

첫째 줄에 정수의 개수 N (1 ≤ N ≤ 1,000,000)이 주어진다. 둘째 줄에는 N개의 정수를 공백으로 구분해서 주어진다. 모든 정수는 -1,000,000보다 크거나 같고, 1,000,000보다 작거나 같은 정수이다.

www.acmicpc.net

문제

N개의 정수가 주어진다. 이때, 최솟값과 최댓값을 구하는 프로그램을 작성하시오.

입력

첫째 줄에 정수의 개수 N (1 ≤ N ≤ 1,000,000)이 주어진다. 둘째 줄에는 N개의 정수를 공백으로 구분해서 주어진다. 모든 정수는 -1,000,000보다 크거나 같고, 1,000,000보다 작거나 같은 정수이다.

출력

첫째 줄에 주어진 정수 N개의 최솟값과 최댓값을 공백으로 구분해 출력한다.

해결방안

1. 둘째 줄의 N개의 정수를 하나의 리스트로 만든다,

2. min(list) 내부모듈 함수를 이용하여 최솟값을 구한다.

3. max(list) 내부모듈 함수를 이용하여 최댓값을 구한다.

소스 코드

import sys
input = sys.stdin.readline
N = int(input())
numbers = list(map(int, input().split()))
min_n = min(numbers)
max_n = max(numbers)
print(' '.join(list(map(str, [min_n, max_n]))))

 

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

 

2562번: 최댓값

9개의 서로 다른 자연수가 주어질 때, 이들 중 최댓값을 찾고 그 최댓값이 몇 번째 수인지를 구하는 프로그램을 작성하시오. 예를 들어, 서로 다른 9개의 자연수 3, 29, 38, 12, 57, 74, 40, 85, 61 이 주어지면, 이들 중 최댓값은 85이고, 이 값은 8번째 수이다.

www.acmicpc.net

문제

9개의 서로 다른 자연수가 주어질 때, 이들 중 최댓값을 찾고 그 최댓값이 몇 번째 수인지를 구하는 프로그램을 작성하시오.

예를 들어, 서로 다른 9개의 자연수

3, 29, 38, 12, 57, 74, 40, 85, 61

이 주어지면, 이들 중 최댓값은 85이고, 이 값은 8번째 수이다.

입력

첫 째 줄부터 아홉 번째 줄까지 한 줄에 하나의 자연수가 주어진다. 주어지는 자연수는 100 보다 작다.

출력

첫째 줄에 최댓값을 출력하고, 둘째 줄에 최댓값이 몇 번째 수인지를 출력한다.

해결방안

1. 첫 째 줄부터 아홉 번째 줄까지의 자연수를 리스트에 차례대로 추가(append)한다.

2. 최대값은 max(list) 함수를 이용하여 구한다.

3. 최대값의 인덱스 값은 list.index(max_value)+1 로 구한다.

 

소스코드

import sys

numbers = []
for line in sys.stdin:
    numbers.append(int(line.strip()))
max_n = max(numbers)
max_idx = numbers.index(max_n)
print(max_n)
print(max_idx+1)

 

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

 

2884번: 알람 시계

문제 상근이는 매일 아침 알람을 듣고 일어난다. 알람을 듣고 바로 일어나면 다행이겠지만, 항상 조금만 더 자려는 마음 때문에 매일 학교를 지각하고 있다. 상근이는 모든 방법을 동원해보았지만, 조금만 더 자려는 마음은 그 어떤 것도 없앨 수가 없었다. 이런 상근이를 불쌍하게 보던, 창영이는 자신이 사용하는 방법을 추천해 주었다. 바로 "45분 일찍 알람 맞추기"이다. 이 방법은 단순하다. 원래 맞춰져있는 알람을 45분 앞서는 시간으로 바꾸는 것이다. 어차피

www.acmicpc.net

문제

상근이는 매일 아침 알람을 듣고 일어난다. 알람을 듣고 바로 일어나면 다행이겠지만, 항상 조금만 더 자려는 마음 때문에 매일 학교를 지각하고 있다.

상근이는 모든 방법을 동원해보았지만, 조금만 더 자려는 마음은 그 어떤 것도 없앨 수가 없었다.

이런 상근이를 불쌍하게 보던, 창영이는 자신이 사용하는 방법을 추천해 주었다.

바로 "45분 일찍 알람 맞추기"이다.

이 방법은 단순하다. 원래 맞춰져있는 알람을 45분 앞서는 시간으로 바꾸는 것이다. 어차피 알람 소리를 들으면, 알람을 끄고 조금 더 잘 것이기 때문이다. 이 방법을 사용하면, 매일 아침 더 잤다는 기분을 느낄 수 있고, 학교도 지각하지 않게 된다.

현재 상근이가 맞춰논 알람 시각이 주어졌을 때, 창영이의 방법을 사용한다면, 이를 언제로 고쳐야 하는지 구하는 프로그램을 작성하시오.

입력

첫째 줄에 두 정수 H와 M이 주어진다. (0 ≤ H ≤ 23, 0 ≤ M ≤ 59) 그리고 이것은 현재 상근이가 맞춰놓은 알람 시간 H시 M분을 의미한다.

입력 시간은 24시간 표현을 사용한다. 24시간 표현에서 하루의 시작은 0:0(자정)이고, 끝은 23:59(다음날 자정 1분 전)이다. 시간을 나타낼 때, 불필요한 0은 사용하지 않는다.

출력

첫째 줄에 상근이가 창영이의 방법을 사용할 때, 맞춰야 하는 알람 시간을 출력한다. (입력과 같은 형태로 출력하면 된다.)

해결 방안

1. H시 M분에서 45분을 뺀 값을 H'시 M'분이라고 했을 때, 두가지 케이스로 나눠서 생각해볼 수 있다.

1-1. M >= 45 인 경우에는 M-45 >= 0 이므로

  H' = H, M' = M -45

1-2. M < 45 인 경우에는 M-45 < 0 이므로

  H' = H-1, M' = M - 45 + 60 (여기서 H가 0 인 경우에는 H = 23이 된다)

2. 1.번의 케이스를 모드(%)를 이용하면 간단하게 값을 표시할 수 있다.

  M' = (M -45 + 60) % 60 (M < 45인 경우에는  H' = (H + 24 - 1) % 24)

소스 코드

import sys
input = sys.stdin.readline

def TimeAlarm(H, M):
    h = 24
    m = 60
    alarm = 45
    
    if M < alarm:
        H = (H + h - 1) % h
    M = (M + m - alarm) % m
    return H, M
    
H, M = list(map(int, input().split()))
H2, M2 = TimeAlarm(H, M)
print(' '.join(list(map(str,[H2,M2]))))

+ Recent posts