대표값2
시간 제한메모리 제한제출정답맞힌 사람정답 비율
1 초 | 128 MB | 15445 | 9827 | 9082 | 64.673% |
문제
어떤 수들이 있을 때, 그 수들을 대표하는 값으로 가장 흔하게 쓰이는 것은 평균이다. 평균은 주어진 모든 수의 합을 수의 개수로 나눈 것이다. 예를 들어 10, 40, 30, 60, 30의 평균은 (10 + 40 + 30 + 60 + 30) / 5 = 170 / 5 = 34가 된다.
평균 이외의 또 다른 대표값으로 중앙값이라는 것이 있다. 중앙값은 주어진 수를 크기 순서대로 늘어 놓았을 때 가장 중앙에 놓인 값이다. 예를 들어 10, 40, 30, 60, 30의 경우, 크기 순서대로 늘어 놓으면
10 30 30 40 60
이 되고 따라서 중앙값은 30이 된다.
다섯 개의 자연수가 주어질 때 이들의 평균과 중앙값을 구하는 프로그램을 작성하시오.
입력
첫째 줄부터 다섯 번째 줄까지 한 줄에 하나씩 자연수가 주어진다. 주어지는 자연수는 100 보다 작은 10의 배수이다.
출력
첫째 줄에는 평균을 출력하고, 둘째 줄에는 중앙값을 출력한다. 평균과 중앙값은 모두 자연수이다.
예제 입력 1 복사
10
40
30
60
30
예제 출력 1 복사
34
30
풀이
ArrayList에 값을 다받고, 받으면서 총 합을 구한다.
정렬된 리스트의 가운데 값과 총 합을 이용한 평균값 출력
public class Main {
static BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
static BufferedWriter bw = new BufferedWriter(new OutputStreamWriter(System.out));
public static void main(String[] args) throws IOException {
List<Integer> numberList = new ArrayList<>();
int sum = 0;
for (int i = 0; i < 5; i++) {
int currentInputNumber = Integer.parseInt(br.readLine());
numberList.add(currentInputNumber);
sum += currentInputNumber;
}
Collections.sort(numberList);
bw.write(sum/5+"\n"+numberList.get(2));
bw.flush();
bw.close();
}
}
시간복잡도
반복문 -> O(1)
ArrayList.add(1) -> 맨뒤 추가이므로 O(1)
Collections.sort() ->O( NlogN )
총 시간복잡도 : O(1) +O(1) + O(NlogN) = O(NlogN) ?
'자바 > 알고리즘 문제 풀이' 카테고리의 다른 글
백준/2751 수 정렬하기 2 (0) | 2022.12.03 |
---|---|
백준/25305 커트라인 (0) | 2022.12.03 |
백준/2750 수 정렬하기 (0) | 2022.12.03 |
백준/1439 뒤집기 (0) | 2022.10.29 |
백준/2444 별찍기 -7 (0) | 2022.10.28 |
댓글