我现写的一个,简洁明了,应该是符合你的口味的,测试完全通过
#include
#define N 100
typedef struct student
{
int id; //学号
char name[20]; //姓名
int gender; //性别(0代表男生,1代表女生)
float score; //成绩
}stu;
stu s[N];
int main()
{
int i;
for(i=0;i
printf("请输入第%d个学生的学号:",i+1);
scanf("%d",&s[i].id);
printf("请输入第%d个学生的姓名:",i+1);
scanf("%s",&s[i].name);
printf("请输入第%d个学生的性别:",i+1);
scanf("%d",&s[i].gender);
printf("请输入第%d个学生的成绩:",i+1);
scanf("%f",&s[i].score);
}
stu ss[N];
stu* p=ss;
for(i=0;i
for(i=0;i
for(int j=i+1;j
if(ss[i].score
stu temp=*(p+i);
*(p+i)=*(p+j);
*(p+j)=temp;
}
}
}
printf("所有学生的信息按成绩由高到低排名如下:\n");
printf("学号\t姓名\t性别\t成绩\n");
for(i=0;i
printf("%d\t%s\t%d\t%.1f\n",(p+i)->id,(p+i)->name,(p+i)->gender,(p+i)->score);
}
return 0;
}
typedef struct _StudentInfo
{
int nStuID;
char szStuName[64]; // 此处可以new出来一个buf 代替
int nSex;
int nScore;
}STUDENTINFO,*PSTUDENTINFO;
STUDENTINFO *g_pStuInfo[100] = {0};
int Add_StuInfo()
{
STUDENTINFO *pStuInfo = new STUDENTINFO;
memset(pStuInfo, 0, sizeof(STUDENTINFO) );
pStuInfo->nStuId = 1;
strcpy(pStuInfo->szStuName,"ZhangSan");
pStuInfo->nSex = 1;
pStuInfo->nScore = 450;
g_pStuInfo[0] = pStuInfo; // 另写一个接口排序插入数组
}