프로그래밍 도와주세요ㅠ
화가마
질문 제목 :질문 요약체조 경기 점수의 평균을 구하고 입상자를 구하는 프로그램을 작성한다
최대 경기 참가 선수는 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등을 찾아서 동메달로 출력하면 되겠습니다
번호 | 제 목 | 글쓴이 | 날짜 |
---|---|---|---|
2676005 | keybd_event 게임 제어 | 영글 | 2024-11-23 |
2675900 | 진짜기본적인질문 | 글길 | 2024-11-22 |
2675845 | 수정좀해주세요ㅠㅠㅠ | 해골 | 2024-11-21 |
2675797 | 병합 정렬 소스 코드 질문입니다. (2) | 도래솔 | 2024-11-21 |
2675771 | 큐의 활용이 정확히 어떻게 되죠?? | 해긴 | 2024-11-21 |
2675745 | 도서관리 프로그램 질문이요 | 도리도리 | 2024-11-20 |
2675717 | 2진수로 변환하는것! (3) | 동생몬 | 2024-11-20 |
2675599 | for문 짝수 출력하는 법 (5) | 널위해 | 2024-11-19 |
2675575 | Linux 게시판이 없어서.. | 첫삥 | 2024-11-19 |
2675545 | 구조체 이용할 때 함수에 자료 넘겨주는 것은 어떻게 해야 하나요? | 아연 | 2024-11-19 |
2675518 | 사각형 가로로 어떻게 반복해서 만드는지좀.. 내용 | 신당 | 2024-11-18 |
2675491 | !느낌표를 입력하는것은 어떻게합니까~~?ㅠㅠ (5) | 사지타리우스 | 2024-11-18 |
2675411 | 파일입출력으로 받아온 파일의 중복문자열을 제거한 뒤 파일출력 | 앨버트 | 2024-11-17 |
2675385 | 링크드리스트 주소록 질문드립니다. (1) | 겨루 | 2024-11-17 |
2675356 | 2진수를 10진수로 바꾸려고 하는데 막히네요.. | 풀잎 | 2024-11-17 |
2675297 | Prity 비트 발생기 | 한란 | 2024-11-16 |
2675249 | C책 좀 추천해 주세요 (2) | 딸기우유 | 2024-11-16 |
2675193 | 연습문제 17-1 질문입니다. | 한별나라 | 2024-11-15 |
2675172 | 소스점 | 아이뻐 | 2024-11-15 |
2675146 | 단순 연결 리스트인데 출력결과가 이상하게 나와요. | 찬늘봄 | 2024-11-15 |