일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 | 29 | 30 |
Tags
- for
- error
- IFELSE
- Scanner class
- IF
- java
- 알고리즘
- IF문
- 백준알고리즘
- java프로그래밍
- Spring
- 유비쿼터스
- 자바
- MySQL
- 파이썬프로그래밍기초
- 배열
- 기본
- FOR문
- 함수
- 스캐너
- Scanner
- 하드웨어
- 반복문
- 자료구조
- 백준
- 변수
- 스캐너클래스
- 1차원배열
- 데이터
- C언어
Archives
- Today
- Total
정리하고기록하자
백준 (JAVA) - 평균 (1546) 본문
반응형
백준 - 알고리즘 1차원배열 평균 (1546) 문제
문제 : 세준이는 기말고사를 망쳤다. 세준이는 점수를 조작해서 집에 가져가기로 했다. 일단 세준이는 자기 점수 중에 최댓값을 골랐다. 이 값을 M이라고 한다. 그리고 나서 모든 점수를 점수/M*100으로 고쳤다.
예를 들어, 세준이의 최고점이 70이고, 수학점수가 50이었으면 수학점수는 50/70*100이 되어 71.43점이 된다.
세준이의 성적을 위의 방법대로 새로 계산했을 때, 새로운 평균을 구하는 프로그램을 작성하시오.
입력 : 첫째 줄에 시험 본 과목의 개수 N이 주어진다. 이 값은 1000보다 작거나 같다. 둘째 줄에 세준이의 현재 성적이 주어진다. 이 값은 100보다 작거나 같은 음이 아닌 정수이고, 적어도 하나의 값은 0보다 크다.
출력 : 첫째 줄에 새로운 평균을 출력한다. 실제 정답과 출력값의 절대오차 또는 상대오차가 10-2 이하이면 정답이다.
일단 문제에서 최댓값 M 을 먼저 구한다.
public static void main(String[] args) {
Scanner sc = new Scanner(System.in);
int[] n = new int[sc.nextInt()]; // 배열 생성
int max = 0; // 최댓값 변수
int sum = 0; // 합
// 배열의 크기 만큼 반복문을 돌린다.
for( int i = 0; i < n.length; i ++) {
// 각 배열의 원소에 값을 넣는다.
int b = sc.nextInt();
// 만약 최댓값 변수의 값이 입력한 원소의 값보다 클 경우
if( max < b ) {
// 최댓값은 입력한 원소의 값으로 바꾼다.
max = b;
}
// 입력한 원소의 값들의 합
sum += b;
}
System.out.println("max : " + max); // 최댓값 구해졌는지 찍어보자
System.out.println("sum : " + sum); // 합계도 찍어보자
sc.close();
}
이렇게 최댓값과 합계를 구했다.
그다음 평균을 구하자
double avg = sum / n.length;
출력 결과를 보면 소수점까지 출력을 해야 하기 때문에 double 로 선언을 했다.
평균까지 구했고 이제 값을 출력 해보자.
double newAvg = avg / max * 100;
System.out.println( newAvg );
public class Main {
public static void main(String[] args) {
// TODO Auto-generated method stub
Scanner sc = new Scanner(System.in);
int[] n = new int[sc.nextInt()];
int max = 0;
int sum = 0;
for( int i = 0; i < n.length; i ++) {
int b = sc.nextInt();
if( max < b ) {
max = b;
}
sum += b;
}
System.out.println("max : " + max);
System.out.println("sum : " + sum);
sc.close();
double avg = sum / n.length;
double newAvg = avg / max * 100;
System.out.println( newAvg );
}
}
완성코드 이고 이클립스에서 실행했을때 입력한 결과는 출력이 되었지만
백준에서는 틀렸다고 한다.
여기서 부터 구글링
평균값 구하기
double avg = (double)sum / (double)max * 100 / n.length;
마지막으로 int 형 sum , max 를 double 로 형변환 후 출력 하였다
import java.util.Scanner;
public class Main {
public static void main(String[] args) {
// TODO Auto-generated method stub
Scanner sc = new Scanner(System.in);
int[] n = new int[sc.nextInt()];
int max = 0;
int sum = 0;
for( int i = 0; i < n.length; i ++) {
int b = sc.nextInt();
if( max < b ) {
max = b;
}
sum += b;
}
sc.close();
double avg = (double)sum / (double)max * 100 / n.length;
System.out.println( avg );
}
}
끝!
반응형
'백준 - 알고리즘' 카테고리의 다른 글
백준 (JAVA) - 정수 N개의 합 (15596) (0) | 2022.02.11 |
---|---|
백준 (JAVA) - OX퀴즈 (8958) (0) | 2022.02.10 |
백준 (JAVA) - 나머지 (3052) (0) | 2021.11.22 |
백준 (JAVA) - 숫자의 개수 (2577) (0) | 2021.11.17 |
백준 (JAVA) - 최댓값 (2562) (2) | 2021.11.16 |