C语言考试试题:定义一个100位学生的结构体数组,按成绩从高到低进行排序
C语言考试试题:定义一个100位学生的结构体数组,按成绩从高到低进行排序,信息包括学号,姓名,性别,成绩,其中要利用到指针!谢谢~...
C语言考试试题:定义一个100位学生的结构体数组,按成绩从高到低进行排序,信息包括学号,姓名,性别,成绩,其中要利用到指针!谢谢~
展开
展开全部
我现写的一个,简洁明了,应该是符合你的口味的,测试完全通过
#include <stdio.h>
#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<N;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<N;i++)
ss[i]=s[i];
for(i=0;i<N-1;i++)
{
for(int j=i+1;j<N;j++)
{
if(ss[i].score<ss[j].score)
{
stu temp=*(p+i);
*(p+i)=*(p+j);
*(p+j)=temp;
}
}
}
printf("所有学生的信息按成绩由高到低排名如下:\n");
printf("学号\t姓名\t性别\t成绩\n");
for(i=0;i<N;i++)
{
printf("%d\t%s\t%d\t%.1f\n",(p+i)->id,(p+i)->name,(p+i)->gender,(p+i)->score);
}
return 0;
}
#include <stdio.h>
#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<N;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<N;i++)
ss[i]=s[i];
for(i=0;i<N-1;i++)
{
for(int j=i+1;j<N;j++)
{
if(ss[i].score<ss[j].score)
{
stu temp=*(p+i);
*(p+i)=*(p+j);
*(p+j)=temp;
}
}
}
printf("所有学生的信息按成绩由高到低排名如下:\n");
printf("学号\t姓名\t性别\t成绩\n");
for(i=0;i<N;i++)
{
printf("%d\t%s\t%d\t%.1f\n",(p+i)->id,(p+i)->name,(p+i)->gender,(p+i)->score);
}
return 0;
}
更多追问追答
追问
/tmp/c_I1wgVf:31: error: 'for' loop initial declaration used outside C99 mode
展开全部
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; // 另写一个接口排序插入数组
}
{
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; // 另写一个接口排序插入数组
}
本回答被网友采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询
广告 您可能关注的内容 |