프로그래밍 도와주세요ㅠ
화가마
질문 제목 :질문 요약체조 경기 점수의 평균을 구하고 입상자를 구하는 프로그램을 작성한다
최대 경기 참가 선수는 20명까지 가능하도록 한다. 실제 참가자 수는 20명보다 많으면 20명까지만 입력받아 처리하고, 적으면 그 인원대로 처리한다.
5명의 심판이 심사를 하고, 각 선수의 점수는 최고 점수와 최저 점수 하나씩을 제외한 나머지 3개의 점수를 평균하여 구한다
금메달, 은메달, 동메달 입상자를 구한다
점수는 0~100점까지 주어질 수 있다
동점자가 있을 경우, 번호가 빠른 선수가 순위가 높도록 처리한다.
질문 내용 :체조경기평가프로그램인데 여기서 20명까지 가능하도록 하는것과 동점자가 있을 경우 번호가 빠른 선수가 순위가 되도록 하는 법을 모르겠네요ㅠ 아래는 코딩입니다.
#include stdio.h#define player_max 20typedef struct{
int no; int score[5]; int max; int min; int total; float average; int rank;}
player;int main(void)
{
file *fpin, *fpout; player player[player_max];
int i, j;
fpin = fopen(gymnastics.inp, r);
if (fpin == null)
{
printf(file not found!);
return -1;
} for (i = 0; i player_max; i++)
{
fscanf(fpin, %d, &player[i].no);
for (j = 0; j 5; j++)
{
fscanf(fpin, %d, &player[i].score[j]);
}
}
fclose(fpin);
for (i = 0; i player_max; i++)
{
player[i].max = player[i].score[0];
player[i].min = player[i].score[0];
player[i].total = 0;
for (j = 0; j 5; j++)
{
if (player[i].score[j] player[i].max)
player[i].max = player[i].score[j];
if (player[i].score[j] player[i].min)
player[i].mier[i].min = player[i].score[j];
player[i].total += player[i].score[j];
}
player[i].total -= player[i].max + player[i].min;
player[i].average = player[i].total / 3.0f;
}
for (i = 0; i player_max; i++)
{
player[i].rank = 1;
for (j = 0; j player_max; j++)
{
if (player[j].average player[i].average)
{
player[i].rank++;
}
}
}
fpout = fopen(gymnastics.out, w);
for (i = 0; i player_max; i++)
{
fprintf(fpout, %d %0.2f\n, player[i].no, player[i].average);
} fprintf(fpout, \n);
for (i = 0; i player_max; i++)
{
if (player[i].rank == 1)
{
fprintf(fpout, 금메달 %d\n, player[i].no);
}
}
for (i = 0; i player_max; i++)
{
if (player[i].rank == 2)
{
fprintf(fpout, 은메달 %d\n, player[i].no);
}
}
for (i = 0; i player_max; i++)
{
if (player[i].rank == 3)
{
fprintf(fpout, 동메달 %d\n, player[i].no);
}
}
fclose(fpout);
return 0;
}
-
에다
파일을 읽을 때 20으로 루프 돌기 때문에 20이란 조건은 성립하고
만약 20 미만일 경우를 생각해서 eof에 도달하면 읽기를 멈추시면 되겠네요.
메달을 출력할 때도 0부터 루프를 돌기 때문에
자동으로 빠른 번호가 먼저 검사 됩니다.
다만, 동점자가 있을 것을 감안해서
배열을 따로 하나 더 만들고 거기에 금메달 동점자를 넣고
금메달 동점자를 각각 은, 동을 처리하고
만약 금메달 동점자 중에
동메달이 않나오면 2등을 찾아서 동메달로 출력하면 되겠습니다
번호 | 제 목 | 글쓴이 | 날짜 |
---|---|---|---|
2655491 | 키보드 인식, 랜덤 함수 or 헤더 (2) | 별 | 2024-05-20 |
2655471 | 링 버퍼 구현된 소스 인데요.. 이해가 잘안되서요.. | 소심한녀자 | 2024-05-20 |
2655440 | test파일이 안 되요. (2) | 리라 | 2024-05-19 |
2655416 | 고수님들 도움이 절실합니다. (2) | 세리 | 2024-05-19 |
2655361 | 엔터 입력받을때까지 기다리는 getchar (1) | 큰모음 | 2024-05-19 |
2655328 | 함수에서 포인터 (3) | 모아 | 2024-05-18 |
2655299 | 아이콘바꾸는법..? | 소 | 2024-05-18 |
2655271 | scanf 입력받으면 쭉 실행되는.. (5) | ComeOn | 2024-05-18 |
2655184 | 이 세개 프로그램좀 해결해주실.... 고수님들???? (3) | 말달리자 | 2024-05-17 |
2655129 | 다차원 배열 원소들 주소계산하는거 질문이요~ | 터전 | 2024-05-17 |
2655103 | AVRstudio MoveAxis. MoveLine 함수질문 | 앨버트 | 2024-05-16 |
2655072 | 콘솔창의 위치와 크기를 정하고 싶습니다. | 딥레드 | 2024-05-16 |
2655044 | 자료구조랑 online judge site에 대해서 질문있습니다... (1) | 뽀송뽀송 | 2024-05-16 |
2655016 | 별찍기 문제 중 이해안되는 부분이 있어요... | 도전중 | 2024-05-16 |
2654986 | 입력받은 성적을 배열에 저장하기 (3) | 안녕나야 | 2024-05-15 |
2654959 | ===========-이런거 미리 지정하는법 (1) | 김자영 | 2024-05-15 |
2654930 | 도와주십시요 ㅜㅜ 자료구조 ㅜㅜ | 도널드 | 2024-05-15 |
2654881 | PID 모듈 검색 부분 질문합니다 . | 이름없음 | 2024-05-14 |
2654850 | 조건에 만족하는 다음 수를 찾고 싶습니다. | 초엘 | 2024-05-14 |
2654790 | 두파일간 byte단위 txt파일 복사 中 | 슬찬 | 2024-05-14 |