일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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
- Linux
- 정보올림피아드
- 정보영재원
- 제어문
- if문
- 다중반복문
- 문제출저:www.dovelet.com
- 영재교육원
- 리눅스
- 참조은요양병원
- For문
- 리눅스 명령어
- DBMS
- 수학영재원
- 자료구조
- 배열
- 정보과학
- C++
- 백도어
- 프로그래밍
- 풀이&소스코드저작권:왕유승
- Backdoor
- 독서 감상문
- C
- 알고리즘
- API
- 독후감
- c언어
- IT
- 반복문
Archives
- Today
- Total
되는대로 살자
[C언어 기출문제&풀이] 분산 본문
프로그램 명: variation
제한시간: 1 초
- A 반의 학생 수가 3 명 이고 , 각 학생의 수학 점수가 3,4,5
- B 반의 학생 수가 3 명 이고 , 각 학생의 수학 점수가 1,4,7
그런데 두 반의 점수의 흩어진 정도는 B 반이 더 크지만 평균으로는 흩어진 정도는 알수는 없다. 흩어진 정도를 측정하는 대표적인 방법이 분산(variation) 이다.
분산은 각 데이터(변량)에서 평균값을 뺀 값의 제곱의 합을 인원수로 나누는 것으로 약속한다.
- A 반의 분산은 (3-4)^2 + (4-4)^2 + (5-4)^2 를 3 으로 나눈 값이고
- B 반의 분산은 (1-4)^2 + (4-4)^2 + (7-4)^2 를 3 으로 나눈 값이다.
분산이 더 크다는 것은 흩어진 정도(산포도)가 더 크다는 것을 의미한다.
문제는 반의 인원수와 수학점수가 주어질 때 이 반의 수학점수의 분산을 구하는 것이다.
입력
첫 째 줄에는 인원 수 n 이 입력으로 주어진다. 다음 줄에는 n 개의 정수가 입력으로 주어진다. 각 수는 1 이상 100 이하이다.n 은 3 이상 100 이하이다.
출력
소수 2 자리까지 출력한다.입출력 예
입력 4 1 2 3 4 출력 1.25
출처:dovelet
소스코드
int n,i,jumsu[100];
float average=0,variance=0;
scanf("%d",&n);
for(i=0;i<n;i++)
{
scanf("%d",&jumsu[i]);
average+=jumsu[i];
}
average/=n;
for(i=0;i<n;i++)
variance+=(jumsu[i]-average)*(jumsu[i]-average);
printf("%2.2f",variance/=n);
}
'2009~2014 > C/C++' 카테고리의 다른 글
[C언어 기출문제&풀이] 서로 다른 수의 개수 (0) | 2010.11.14 |
---|---|
[C언어 기출문제&풀이] 점수계산 (0) | 2010.11.14 |
[C언어 기출문제&풀이] 최소 위치 출력 (0) | 2010.11.14 |
[C언어 기출문제&풀이] hy expense (0) | 2010.11.14 |
[C언어 기출문제&풀이] dfact (0) | 2010.11.14 |