Baekjoon Online Judge
문제
동호는 새악대로 T 통신사의 새 핸드폰 옴머나를 샀다. 새악대로 T 통신사는 동호에게 다음 두 가지 요금제 중 하나를 선택하라고 했다.
- 영식 요금제
- 민식 요금제
영식 요금제는 30초마다 10원씩 청구된다. 이 말은 만약 29초 또는 그 보다 적은 시간 통화를 했으면 10원이 청구된다. 만약 30초부터 59초 사이로 통화를 했으면 20원이 청구된다.
민식 요금제는 60초마다 15원씩 청구된다. 이 말은 만약 59초 또는 그 보다 적은 시간 통화를 했으면 15원이 청구된다. 만약 60초부터 119초 사이로 통화를 했으면 30원이 청구된다.
동호가 저번 달에 새악대로 T 통신사를 이용할 때 통화 시간 목록이 주어지면 어느 요금제를 사용 하는 것이 저렴한지 출력하는 프로그램을 작성하시오.
입력
동호가 저번 달에 이용한 통화의 개수 N이 주어진다. N은 20보다 작거나 같은 자연수이다. 둘째 줄에 통화 시간 N개가 주어진다. 통화 시간은 10,000보다 작거나 같은 자연수이다.
출력
첫째 줄에 싼 요금제의 이름을 출력한다. 그 후에 공백을 사이에 두고 요금이 몇 원 나오는지 출력한다. 만약 두 요금제의 요금이 모두 같으면 영식을 먼저 쓰고 민식을 그 다음에 쓴다.
영식은 Y로, 민식은 M으로 출력한다.
예제 입력 | 예제 출력 |
3 40 40 40 |
M 45 |
3 61 61 61 |
Y M 90 |
2 61 10 |
Y 40 |
2 60 65 |
Y M 60 |
풀이
#include <iostream>
using namespace std;
int main() {
int N; // 동호가 저번 달에 이용한 통화의 개수
cin >> N;
// 금액 청구 인정되는 시간
int yCount = 0, mCount = 0;
for (int i = 0; i < N; i++) {
int M;
cin >> M;
yCount += (M / 30) + 1;
mCount += (M / 60) + 1;
}
// 각 요금제별 청구 금액
int yCost = yCount * 10;
int mCost = mCount * 15;
// 출력
if (yCost < mCost)
printf("Y %d\n", yCost);
else if (yCost == mCost)
printf("Y M %d\n", yCost);
else
printf("M %d", mCost);
return 0;
}
입력 받은 통화 시간을 요금제별 추가 금액 시간으로 나눠서 요금이 추가되는 횟수를 구했다. 이때 요금이 추가되는 시간보다 적게 통화를 해도 기본 요금이 청구되므로 1을 더했다. 그 뒤에 각 요금제별 청구 금액을 곱한 뒤 그 값 중 작은 것을 선택해서 출력했다.
'백준 > C++' 카테고리의 다른 글
[Baekjoon/C++] 1284번 집 주소 (0) | 2022.05.06 |
---|---|
[Baekjoon/C++] 1268번 임시 반장 정하기 (0) | 2022.05.06 |
[Baekjoon/C++] 1264번 모음의 개수 (0) | 2022.05.06 |
[Baekjoon/C++] 1259번 팰린드롬수 (0) | 2022.05.06 |
[Baekjoon/C++] 1252번 이진수 덧셈 (0) | 2022.05.06 |