랜덤함수 석차
세이
질문 제목 : 랜덤함수의 석차랜덤함수의 석차를 구하는데요. 동점자 처리의 관한 질문입니다.질문 내용 : 랜덤함수의 석차를 구햇는데요. 문제는 동점자에 관한 질문입니다.
만약 동점자가 발생하게 되서 2등이 두명이 되면,
점수 석차
50 1
40 2
40 2
30 4
이런식으로 만들려고 하는데요.
제가만든 것은
점수 석차
50 1
403
403
30 4
이런식으로 출력됩니다.
어떤식으로 고쳐야하는지 알려주세요
#include stdio.h
#include stdlib.h
#include time.h
void main(void)
{
int arr[10][7]={0};
int i, j, k=1, max, min;
int max1, min1, max2, min2;
int sum[10]={0};
int avg[10]={0};
int rank[10];
for(i=0; i10; i++)
rank[i]=1;
srand((unsigned)time(null));//난수 초기값
for(i=0; i10; i++)//
{
for(j=0; j7; j++)
{
if(j==0)
{
arr[i][0]=k;
k++;//학번
}
else if(j==4)
{
sum[i] = arr[i][1]+arr[i][2]+arr[i][3];
arr[i][4]=sum[i];//총합
}
else if(j==5)
{
avg[i] = sum[i]/3;
arr[i][5] = avg[i];//평균
}
/* else if(j==6)
{
if(arr[i][5] arr[j][5])
{
rank[i]++;
arr[i][6] = rank[i];
}
} */
else if(j==1 || j==2 || j==3)
arr[i][j]=rand()%101;//시험점수 저장값
}
}
for(i=0; i10; i++)
{
for(j=0; j10; j++)
{
if(arr[i][5] = arr[j][5])
{
arr[i][6] = rank[i];
rank[i]+=1;//석차
}
}
}
printf(| 학번 | 시험 #1 | 시험 #2 | 시험 #3 |&| 총점 l 평균 l 석차 l\n);
for(i=0; i10; i++)
{
for(j=0; j7; j++)
{
printf( %3d , arr[i][j]);
}
printf(\n);
}//시험점수 출력값max=arr[0][1];
min=arr[0][1];
max1=arr[0][2];
min1=arr[0][2];
max2=arr[0][3];
min2=arr[0][3];
for(i=0; i10; i++) // 1번째 시험 최저, 최대
{
if(arr[i][1]max)
max=arr[i][1];
else if(arr[i][1]min)
min=arr[i][1];
}
for(i=0; i10; i++) // 2번째 시험 최저, 최대
{
if(arr[i][2]max1)
max1=arr[i][2];
else if(arr[i][2]min1)
min1=arr[i][2];
}
for(i=0; i10; i++) // 3번째 시험 최저, 최대
{
if(arr[i][3]max2)
max2=arr[i][3];
else if(arr[i][3]min2)
min2=arr[i][3];
}
printf( 최대 : %3d %3d %d\n 최소 : %3d %3d %d\n, max, max1,max2,min,min1,min2);
}
-
둘빛
rank를 따로 설정하고 arr[i][6]에 다시 석차를 넣는 이유를 잘 모르겠는데 하여튼
for(i=0;i10;i++)
{ arr[i][6] = 0;
for(j=0;j10;j++)
if ( arr[i][5]=arr[j][5] ) arr[i][6] ++;
}
이렇게 하시면 될꺼 같아요. 여기 다른 분이 저렇게 깔끔하게 석차처리 하시더라구요. 전 되게 지저분하게 했었는데 감탄했습니다.