🌞Algorithm/🔥Baekjoon

[Baekjoon] 18706_Coffee

뿌야._. 2025. 2. 7. 15:51
문제(출처: https://www.acmicpc.net/problem/18706)

< Coffee >

 

문제 풀이 

 

각 커피 사이즈별 가격을 HashMap에 저장한다. 손님마다 주문한 커피의 가격을 HashMap에서 찾고, 배달비를 더한다. 

* 지불할 값+1 또는 지불할 값 -1이 5의 배수라면 5의 배수로 값을 지불한다.

 

 my solution (Java)

import java.io.BufferedReader;
import java.io.BufferedWriter;
import java.io.IOException;
import java.io.InputStreamReader;
import java.io.OutputStreamWriter;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.StringTokenizer;

public class _18706_ { // Coffee

	public static void main(String[] args) throws IOException {
		BufferedReader bf = new BufferedReader(new InputStreamReader(System.in));
		BufferedWriter bw = new BufferedWriter(new OutputStreamWriter(System.out));
		StringTokenizer st;
        
		int T = Integer.parseInt(bf.readLine());
        
		for (int i = 0; i < T; i++) {
			st = new StringTokenizer(bf.readLine());
            
			int C = Integer.parseInt(st.nextToken());
			int P = Integer.parseInt(st.nextToken());
            
			HashMap<String, ArrayList<Integer>> map = new HashMap<>();
			for (int j = 0; j < C; j++) {
				st = new StringTokenizer(bf.readLine());
                
				String coffee = st.nextToken();
                
				ArrayList<Integer> temp = new ArrayList<>();
				for (int k = 0; k < 3; k++) {
					temp.add(Integer.parseInt(st.nextToken()));
				}
                
				map.put(coffee, temp);
			}
            
			for (int j = 0; j < P; j++) {
				st = new StringTokenizer(bf.readLine());
				String name = st.nextToken();
                
				String size = st.nextToken();
                
				String coffee = st.nextToken();
                
				int money = 0;
				if (size.equals("small")) {
					money = map.get(coffee).get(0) + (100 / P);
				} else if (size.equals("medium")) {
					money = map.get(coffee).get(1) + (100 / P);
				} else {
					money = map.get(coffee).get(2) + (100 / P);
				}
                
				if ((money + 1) % 5 == 0) {
					money += 1;
				} else if ((money - 1) % 5 == 0) {
					money -= 1;
				}
				bw.write(name + " " + money + "\n");
			}
		}
		bw.flush();
	}
}

 

변수)
T : 테스트 케이스 수
C, P : 커피 수, 사람 수
map : HashMap <커피 이름, ArrayList <Integer>>
coffee : 커피 이름
temp : 커피 사이즈별 가격
name, size, coffee : 이름, 커피 사이즈, 커피 이름
money : 지불할 값

 

테스트 케이스 수를 입력받는다. 테스트 케이스 수만큼 다음 과정을 반복한다.

 

1) C, P 입력

2) 커피 수만큼 커피 이름과 사이즈별 가격을 입력받아 HashMap에 저장

3) 사람 수만큼 이름, 커피 사이즈, 커피 이름을 입력받아 HashMap에서 지불할 값을 찾음. 이때 배달비 100/P도 더함

4) 만약 지불할 값-1 또는 지불할 값+1이 5의 배수라면 5의 배수로 값을 변경함

5) 이름과 지불할 금액 출력 



 

'🌞Algorithm > 🔥Baekjoon' 카테고리의 다른 글

[Baekjoon] 4368_Babelfish  (0) 2025.02.11
[Baekjoon] 4675_Word Amalgamation  (0) 2025.02.10
[Baekjoon] 14455_Don't Be Last!  (1) 2025.02.06
[Baekjoon] 4351_Hay Points  (1) 2025.02.05
[Baekjoon] 6513_Deli Deli  (1) 2025.02.04