본문 바로가기

Kotlin/Kotlin Algorithm

[백준] 1546. 평균 ( Kotlin, Java )

728x90
반응형

 

 

 

평균

 

https://www.acmicpc.net/problem/1546

 

1546번: 평균

첫째 줄에 시험 본 과목의 개수 N이 주어진다. 이 값은 1000보다 작거나 같다. 둘째 줄에 세준이의 현재 성적이 주어진다. 이 값은 100보다 작거나 같은 음이 아닌 정수이고, 적어도 하나의 값은 0보

www.acmicpc.net

 

 

 

 

 

 

 

문제

세준이는 기말고사를 망쳤다. 세준이는 점수를 조작해서 집에 가져가기로 했다. 일단 세준이는 자기 점수 중에 최댓값을 골랐다. 이 값을 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
반응형