Notice
Recent Posts
Recent Comments
Link
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | ||||||
2 | 3 | 4 | 5 | 6 | 7 | 8 |
9 | 10 | 11 | 12 | 13 | 14 | 15 |
16 | 17 | 18 | 19 | 20 | 21 | 22 |
23 | 24 | 25 | 26 | 27 | 28 |
Tags
- Programmers
- 프로그래머스
- 알고리즘
- 오름차순 정렬
- Lv1
- lv0
- 삼각형의 완성조건
- 문자열
- Stack
- 프로그래머스 자바
- 백준
- COS Pro
- 자바
- 프로그래머스 풀이
- 스프링부트 도커로 배포
- 클라이언트
- index of
- SWEA
- 백준 N과 M 자바
- 큐
- java
- 버퍼
- 프로그래머스 문자열 정렬
- 이진수 변환
- 스택
- 스프링부트 도커 배포
- StringTokenizer
- lv2
- Queue
- 스프링부트 도커
Archives
- Today
- Total
mun dev
[백준] 25206 너의 평점은 자바(Java) 본문
문제설명
인하대학교 컴퓨터공학과를 졸업하기 위해서는, 전공평점이 3.3 이상이거나 졸업고사를 통과해야 한다. 그런데 아뿔싸, 치훈이는 깜빡하고 졸업고사를 응시하지 않았다는 사실을 깨달았다!
치훈이의 전공평점을 계산해주는 프로그램을 작성해보자.
전공평점은 전공과목별 (학점 × 과목평점)의 합을 학점의 총합으로 나눈 값이다.
인하대학교 컴퓨터공학과의 등급에 따른 과목평점은 다음 표와 같다.
A+ | 4.5 |
A0 | 4.0 |
B+ | 3.5 |
B0 | 3.0 |
C+ | 2.5 |
C0 | 2.0 |
D+ | 1.5 |
D0 | 1.0 |
F | 0.0 |
P/F 과목의 경우 등급이 P또는 F로 표시되는데, 등급이 P인 과목은 계산에서 제외해야 한다.
과연 치훈이는 무사히 졸업할 수 있을까?
입력
20줄에 걸쳐 치훈이가 수강한 전공과목의 과목명, 학점, 등급이 공백으로 구분되어 주어진다.
출력
치훈이의 전공평점을 출력한다.
정답과의 절대오차 또는 상대오차가 10−4 이하이면 정답으로 인정한다.
제한
- 1 ≤ 과목명의 길이 ≤ 50
- 과목명은 알파벳 대소문자 또는 숫자로만 이루어져 있으며, 띄어쓰기 없이 주어진다. 입력으로 주어지는 모든 과목명은 서로 다르다.
- 학점은 1.0,2.0,3.0,4.0중 하나이다.
- 등급은 A+,A0,B+,B0,C+,C0,D+,D0,F,P중 하나이다.
- 적어도 한 과목은 등급이 P가 아님이 보장된다.
✅ 통과한 코드
import java.util.*;
import java.io.*;
public class Main {
public static void main(String[] args) throws IOException {
BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
StringTokenizer st;
double scoreNum[] = {4.5, 4.0, 3.5, 3.0, 2.5, 2.0, 1.5, 1.0, 0.0};
String score[] = {"A+", "A0", "B+", "B0", "C+", "C0", "D+", "D0", "F"};
String str[]=new String[20];
double result=0;
double scoreSum=0;
for (int i = 0; i < 20; i++) {
str[i]=br.readLine();
st= new StringTokenizer(str[i]," ");
String subject = st.nextToken();
double num = Double.parseDouble(st.nextToken());
String grade = st.nextToken();
for(int j=0; j<score.length; j++){
if(grade.equals(score[j])){
result+=(num*scoreNum[j]);
if(j!=9){
scoreSum+=num;
}
}
}
}
result/=scoreSum;
System.out.printf("%.6f\n",result);
}
}
'알고리즘 > 백준' 카테고리의 다른 글
[백준] 2468 안전영역 자바(Java) (0) | 2023.04.27 |
---|---|
[백준] 1459 걷기 자바(Java) (0) | 2023.04.27 |
[백준] 10989 수 정렬하기3 자바(Java) (0) | 2023.04.18 |
[백준] 14425 문자열 집합 자바(Java) (0) | 2023.04.18 |
[백준] 2745 진법 변환 자바(Java) (0) | 2023.04.18 |