문제 링크
https://www.acmicpc.net/problem/17479
문제
2019년 1학기가 시작되고 많은 사람을 만나며 밥과 술에 탕진을 해버린 영기는 2학기에 탕진할 돈을 마련하기 위해 중앙대 근처의 고급 레스토랑, "정식당"에서 알바를 하게 되었다.
정식당의 사장 정우는 새로 들어온 알바생 영기를 위해 정식당만의 특별한 음식 주문법을 알려주려고 한다.
정식당에는 다양한 메뉴들이 있지만 크게 3가지로 나눌 수 있는데 A개의 "일반메뉴", B개의 "특별메뉴", C개의 "서비스메뉴"로 나뉘어져 있다. 일반메뉴는 자유롭게 주문할 수 있으나 특별메뉴와 서비스메뉴는 주문할 때 다음의 제약이 있다.
- 특별메뉴는 일반메뉴에서 총 20,000원 이상을 주문해야 주문할 수 있다.
- 서비스메뉴는 일반메뉴와 특별메뉴에서 총 50,000원 이상을 주문해야 주문할 수 있다.
- 서비스메뉴는 단 하나만 주문할 수 있다.
다양한 메뉴와 특별한 메뉴 주문법에 영기는 알바를 하면서 혼돈이 오기 시작했다. 받아서는 안될 주문을 받기도 하며 사장님에게 된통 혼나기도 하며 심지어는 자기 발에 걸려 넘어지기까지 했다.
가게를 찾아온 손님들이 주문하는 것이 옳은 주문인지 아닌지 헷갈려하는 영기는 우리에게 도움을 요청했다. 영기가 주문을 잘 받아올 수 있도록 우리가 도와주자.
입력
첫째 줄에 50,000 이하의 양의 정수 A, B, C가 공백을 두고 주어진다.
두번째 줄부터 A줄에 걸쳐 일반메뉴의 이름과 가격이 공백을 두고 주어진다. 그 다음 B줄에 걸쳐 특별메뉴의 이름과 가격이 공백을 두고 주어진다. 그 다음 C줄에 걸쳐 서비스메뉴의 이름이 주어진다.
그 다음 줄에서 손님이 주문하는 음식의 수를 나타내는 150,000 이하의 자연수 N이 주어진다.
그 다음 N줄에 걸쳐 손님이 주문하는 음식의 이름들이 주어진다. 같은 음식을 여러번 주문할 수도 있으며 메뉴에 있는 음식만 주문한다.
일반메뉴와 스페셜메뉴의 가격은 1,000,000 이하의 양의 정수이며 메뉴의 이름은 20자 이하의 알파벳 소문자로만 이루어져 있으며 일반메뉴, 특별메뉴, 그리고 서비스메뉴들의 이름은 모두 다르다
출력
영기가 받은 주문이 옳은 주문이면 "Okay"를, 그렇지 않은 주문이라면 "No"를 출력하자. 따옴표는 출력하지 않는다.
예제 입력 1
3 2 3
noodle 10000
tteokbokki 5000
sundae 7000
cutlet 12000
friedrice 8000
dumpling
potatochips
fishcake
6
noodle
noodle
cutlet
friedrice
cutlet
potatochips
예제 출력 1
Okay
일반메뉴는 noodle 2개로 20,000원, 특별메뉴는 cutlet 2개와 friedrice 1개로 32,000원, 둘이 합쳐 52,000원으로 서비스메뉴 하나를 주문할 수 있다.
노트
이 문제는 픽션입니다. 문제에 나오는 인물, 사건, 배경은 실제와 아무런 관련이 없습니다.
알고리즘 분류
- 자료 구조
풀이
메뉴의 정보를 map 자료구조를 활용하여 저장한다. 그리고 N개의 주문 내역을 보고 메뉴를 분리해서 일반 메뉴 가격, 특별 메뉴 가격, 서비스 메뉴의 개수를 기록한다.
마지막으로 경우의 수를 따져가면서 Okay를 출력해야 하는지, No를 출력해야 하는지를 분류한다.
코드
#include <iostream>
#include <string>
#include <cmath>
#include <set>
#include <unordered_map>
#include <bitset>
#include <ctime>
#include <stack>
#include <queue>
#include <vector>
#include <algorithm>
#include <climits>
#define FASTIO cin.tie(NULL); cout.tie(NULL); ios::sync_with_stdio(false);
#define MAX 150001
#define LL long long
#define INF 1e9
using namespace std;
int A, B, C, N;
unordered_map<string, LL> UM[3];
LL ACost = 0, BCost = 0;
int Special = 0;
bool Answer = true;
void Input() {
cin >> A >> B >> C;
for (int i = 0; i < A; i++) {
string S;
LL D;
cin >> S >> D;
UM[0].insert(make_pair(S, D));
}
for (int i = 0; i < B; i++) {
string S;
LL D;
cin >> S >> D;
UM[1].insert(make_pair(S, D));
}
for (int i = 0; i < C; i++) {
string S;
cin >> S;
UM[2].insert(make_pair(S, 0));
}
}
void Settings() {
cin >> N;
for (int i = 0; i < N; i++) {
string S;
cin >> S;
if (UM[0].find(S) != UM[0].end()) { // 일반 메뉴면 조건 없이 주문 가능
ACost += UM[0][S];
}
else if (UM[1].find(S) != UM[1].end()) { // 특별 메뉴면 20,000원 이상 주문해야 주문 가능
BCost += UM[1][S];
}
else if (UM[2].find(S) != UM[2].end()) { // 서비스 메뉴면 50,000원 이상 주문해야 하고 하나만 주문 가능
Special++;
}
}
}
void Find_Answer() {
if (ACost >= 20000) {
if (ACost + BCost >= 50000) {
if (Special <= 1) {
cout << "Okay\n";
}
else {
cout << "No\n";
}
}
else {
if (Special >= 1) {
cout << "No\n";
}
else {
cout << "Okay\n";
}
}
}
else {
if ((BCost > 0) || (Special >= 1)) {
cout << "No\n";
}
else {
cout << "Okay\n";
}
}
}
int main() {
FASTIO
Input();
Settings();
Find_Answer();
return 0;
}
'BOJ > Silver' 카테고리의 다른 글
[BOJ/Silver 5] 백준 21966 (중략)(C++) (0) | 2022.05.26 |
---|---|
[BOJ/Silver 3] 백준 1614 영식이의 손가락(C++) (0) | 2022.05.26 |
[BOJ/Silver 3] 백준 17264 I AM IRONMAN(C++) (0) | 2022.05.09 |
[BOJ/Silver 1] 백준 2002 추월(C++) (0) | 2022.05.06 |
[BOJ/Silver 3] 백준 16165 걸그룹 마스터 준석이(C++) (0) | 2022.05.06 |