728x90
반응형
평균
https://www.acmicpc.net/problem/1546
문제
세준이는 기말고사를 망쳤다. 세준이는 점수를 조작해서 집에 가져가기로 했다. 일단 세준이는 자기 점수 중에 최댓값을 골랐다. 이 값을 M이라고 한다. 그리고 나서 모든 점수를 점수/M*100으로 고쳤다.
예를 들어, 세준이의 최고점이 70이고, 수학점수가 50이었으면 수학점수는 50/70*100이 되어 71.43점이 된다.
세준이의 성적을 위의 방법대로 새로 계산했을 때, 새로운 평균을 구하는 프로그램을 작성하시오.
자바
1. Scanner 사용
import java.util.Scanner;
public class Main {
public static void main(String[] args) {
// (1). 랜덤으로 입력 받을 Scanner 생성, 입력 받은 값을 int N = 배열의 길이가 됨
Scanner scanner = new Scanner(System.in);
int N = scanner.nextInt();
// (2). 1차원 배열 arr 생성
double[] arr = new double[N];
// (3). 배열의 길이(N)만큼 반복, 배열에 각 점수를 저장하기
for (int i = 0; i < N; i++) {
arr[i] = scanner.nextDouble();
}
// (4). scanner close, 합을 담을 변수와 최고 점수를 담을 변수를 생성해서 초기화 함
scanner.close();
double sum = 0;
double max = 0;
// (5). 배열 길이만큼 반복, 최고점은 max에 총점은 sum에 저장
for(int i=0; i < N; i++) {
if (arr[i] > max) max = arr[i];
sum = sum + arr[i];
}
// (6). 문제에서 '총합 * 100 / 최고 점수 / 과목의 수'를 구하라고 했기 때문에 아래와 같이 출력함
System.out.print(sum *100 / max / N);
}
}
2. BufferedReader 사용
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.util.StringTokenizer;
public class Main {
public static void main(String[] args) throws IOException {
// (1)
BufferedReader bufferedReader = new BufferedReader(new InputStreamReader(System.in));
int N = Integer.parseInt(bufferedReader.readLine());
// (2) BufferedReader -> 공백까지 한 번에 받기 때문에 문자열 분리를 위해 StringTokenizer를 사용해준다
double[] arr = new double[N];
StringTokenizer stringTokenizer = new StringTokenizer(bufferedReader.readLine(), " ");
// (3)
for (int i= 0; i< N; i++) {
arr[i] = Double.parseDouble(stringTokenizer.nextToken());
}
// (4)
bufferedReader.close();
double sum = 0;
double max = 0;
// (5)
for(int i= 0; i < N; i++) {
if (arr[i] > max) max = arr[i];
sum = sum + arr[i];
}
// (6)
System.out.print(sum* 100 / max / N);
}
}
코틀린
1. Scanner 사용
import java.util.Scanner
fun main() {
// (1)
val scanner = Scanner(System.`in`)
val N = scanner.nextInt()
// (2)
val arr = DoubleArray(N)
// (3)
for (i in 0 until N) {
arr[i] = scanner.nextDouble()
}
// (4)
scanner.close()
var sum: Double = 0.0
var max: Double = 0.0
// (5)
for (i in 0 until N) {
if (arr[i] > max) max = arr[i]
sum += arr[i]
}
// (6)
println(sum * 100 / max / N)
}
2. BufferedReader 사용
import java.io.BufferedReader
import java.io.InputStreamReader
import java.util.StringTokenizer
fun main() {
// (1)
val bufferedReader = BufferedReader(InputStreamReader(System.`in`))
val N = bufferedReader.readLine().toInt()
// (2)
val arr = DoubleArray(N)
val stringTokenizer = StringTokenizer(bufferedReader.readLine(), " ")
// (3)
for (i in 0 until N) {
arr[i] = stringTokenizer.nextToken().toDouble()
}
// (4)
bufferedReader.close()
var sum = 0.0
var max = 0.0
// (5)
for (i in 0 until N) {
if (arr[i] > max) max = arr[i]
sum += arr[i]
}
// (6)
println(sum * 100 / max / N)
}
728x90
반응형
'Kotlin > Kotlin Algorithm' 카테고리의 다른 글
[Kotlin] 자료 구조와 알고리즘의 이해 (0) | 2023.03.02 |
---|---|
[백준] 11659. 구간 합 구하기4 ( Kotlin, Java ) (0) | 2023.02.23 |
[백준] 11720. 숫자의 합 구하기 ( Kotlin, Java ) (0) | 2023.02.21 |
[Kotlin] Sorting - 삽입 정렬(Insertion Sort) (0) | 2022.03.30 |
[백준 Koltin] 2단계. 조건문 (0) | 2022.03.09 |