Notice
Recent Posts
Recent Comments
Link
«   2025/08   »
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
31
Archives
Today
Total
관리 메뉴

코딩로그

[백준/BOJ/C++] 5800번 성적 통계 본문

YJ/C++

[백준/BOJ/C++] 5800번 성적 통계

Team DAON 2021. 12. 31. 10:25

[문제]

한상덕은 이번에 중덕 고등학교에 새로 부임한 교장 선생님이다. 교장 선생님으로서 첫 번째 일은 각 반의 수학 시험 성적의 통계를 내는 일이다.

중덕 고등학교 각 반의 학생들의 수학 시험 성적이 주어졌을 때, 최대 점수, 최소 점수, 점수 차이를 구하는 프로그램을 작성하시오.

[입력]

첫째 줄에 중덕 고등학교에 있는 반의 수 K (1 ≤ K ≤ 100)가 주어진다. 다음 K개 줄에는 각 반의 학생수 N (2 ≤ N ≤ 50)과 각 학생의 수학 성적이 주어진다. 시험 성적은 0보다 크거나 같고, 100보다 작거나 같은 정수이고, 공백으로 나누어져 있다. 

[출력]

각 반에 대한 출력은 다음과 같이 두 줄로 이루어져 있다.

  • 첫째 줄에는 "Class X"를 출력한다. X는 반의 번호이며 입력으로 주어진 순서대로 1부터 증가한다.
  • 둘째 줄에는 가장 높은 점수, 낮은 점수, 성적을 내림차순으로 정렬했을 때 가장 큰 인접한 점수 차이를 예제 출력과 같은 형식으로 출력한다.

[Source Code]

#include <stdio.h>
#include <iostream>
#include <vector>
#include <string>
#include <algorithm>
#include <cmath>
using namespace std;


int main() {
	int test;
	cin >> test;

	for(int i = 0; i < test; i++){
		int student = 0;
		cin >> student;

		int *arr = new int[student];

		for(int j = 0; j < student; j++){
			int score;
			cin >> score;
			arr[j] = score;
		}

		sort(arr, arr+student);

		int gap = 0;
		for(int j = 1; j < student; j++){
			if(arr[j] - arr[j-1] > gap)
				gap = arr[j] - arr[j-1];
		}

		cout << "Class " << i+1 << "\n";
		cout << "Max " << arr[student-1] << ", Min " << arr[0] << ", Largest gap " << gap <<"\n";
	}
}

[결과 화면]

'YJ > C++' 카테고리의 다른 글

[백준/BOJ/C++] 1547번 공  (0) 2021.12.31
[백준/BOJ/C++] 2442번 별 찍기 - 5  (0) 2021.12.31
[백준/BOJ/C++] 4641번 Doubles  (0) 2021.12.31
[백준/BOJ/C++] 11772번 POT  (0) 2021.12.31
[백준/BOJ/C++] 2703번 Cryptoquote  (0) 2021.12.31