알고리즘 단련장/백준

[백준] 25304 영수증 자바 풀이

snapcoder 2024. 7. 15. 00:11
728x90
반응형
SMALL

문제

준원이는 저번 주에 살면서 처음으로 코스트코를 가 봤다. 정말 멋졌다. 그런데, 몇 개 담지도 않았는데 수상하게 높은 금액이 나오는 것이다! 준원이는 영수증을 보면서 정확하게 계산된 것이 맞는지 확인해보려 한다.

영수증에 적힌,

  • 구매한 각 물건의 가격과 개수
  • 구매한 물건들의 총 금액

을 보고, 구매한 물건의 가격과 개수로 계산한 총 금액이 영수증에 적힌 총 금액과 일치하는지 검사해보자.

입력

첫째 줄에는 영수증에 적힌 총 금액 𝑋가 주어진다.

둘째 줄에는 영수증에 적힌 구매한 물건의 종류의 수 𝑁이 주어진다.

이후 𝑁개의 줄에는 각 물건의 가격 𝑎와 개수 𝑏가 공백을 사이에 두고 주어진다.

출력

구매한 물건의 가격과 개수로 계산한 총 금액이 영수증에 적힌 총 금액과 일치하면 Yes를 출력한다. 일치하지 않는다면 No를 출력한다.

제한

  •  1≤𝑋≤1000000000
  •  1≤𝑁≤100
  •  1≤𝑎≤1000000
  •  1≤𝑏≤10

예제 입력 1 복사

260000
4
20000 5
30000 2
10000 6
5000 8

예제 출력 1 복사

Yes

영수증에 적힌 구매할 물건들의 목록으로 계산한 총 금액은 20000 × 5 + 30000 × 2 + 10000 × 6 + 5000 × 8 = 260000원이다. 이는 영수증에 적힌 총 금액인 260000원과 일치한다. 

예제 입력 2 복사

250000
4
20000 5
30000 2
10000 6
5000 8

예제 출력 2 복사

No
 

 

 

정답 

import java.io.*;
import java.util.*;

public class Main{
    public static void main(String[] args) throws IOException {
        BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
        Long totalCost = Long.parseLong(br.readLine());
        Long totalNum = Long.parseLong(br.readLine());
        int sum = 0;
        
        for (int i=0; i<totalNum; i++){
            StringTokenizer st = new StringTokenizer(br.readLine());
            Long cost = Long.parseLong(st.nextToken());
            Long num = Long.parseLong(st.nextToken());
            
            sum += (cost*num);
        }

        System.out.println(sum == totalCost ? "Yes" : "No");
    }
}
728x90
반응형
LIST