解题思路:
注意事项:
参考代码:
#include <stdio.h>
#include<string.h>
struct student
{
char name[101];
int age;
int grade;
};
void intswap(struct student *p,int i,int j)
{
int t=p[i].age;
p[i].age=p[j].age;
p[j].age=t;
t=p[i].grade;
p[i].grade=p[j].grade;
p[j].grade=t;
}
void print(struct student *p,int n)
{
int i;
for(i=0; i<n; i++)
printf("%s %d %d\n",p[i].name,p[i].age,p[i].grade);
}
void input(struct student *p,int n)
{
int i;
for(i=0; i<n; i++)
scanf("%s%d%d",p[i].name,&p[i].age,&p[i].grade);
}
int main()
{
int n,i,j;
struct student p[1001];
while(scanf("%d",&n)!=EOF)
{
char str[101];
input(p,n);
for(i=0; i<n-1; i++)
for(j=0; j<n-i-1; j++)
{
if(p[j].grade>p[j+1].grade)
{
strcpy(str,p[j].name);
strcpy(p[j].name,p[j+1].name);
strcpy(p[j+1].name,str);
intswap(p,j,j+1);
}
}
for(i=0; i<n-1; i++)
for(j=0; j<n-i-1; j++)
{
if(p[j].grade==p[j+1].grade)
{
if(strcmp(p[j].name,p[j+1].name)>0)
{
strcpy(str,p[j].name);
strcpy(p[j].name,p[j+1].name);
strcpy(p[j+1].name,str);
intswap(p,j,j+1);
}
else if(strcmp(p[j].name,p[j+1].name)==0)
{
if(p[j].age>p[j+1].age)
{
strcpy(str,p[j].name);
strcpy(p[j].name,p[j+1].name);
strcpy(p[j+1].name,str);
intswap(p,j,j+1);
}
}
}
}
print(p,n);
}
return 0;
}
0.0分
0 人评分
C语言程序设计教程(第三版)课后习题11.5 (C语言代码)浏览:972 |
2005年春浙江省计算机等级考试二级C 编程题(2) (C语言代码)浏览:495 |
【回文数(二)】 (C语言代码)浏览:730 |
这可能是一个假的冒泡法浏览:986 |
C语言程序设计教程(第三版)课后习题1.5 (C语言代码)浏览:464 |
C语言程序设计教程(第三版)课后习题5.7 (C语言代码)浏览:685 |
WU-蓝桥杯算法提高VIP-交换Easy (C++代码)浏览:1118 |
C语言程序设计教程(第三版)课后习题8.8 (C语言代码)浏览:1428 |
【计算两点间的距离】 (C语言代码)浏览:1493 |
printf基础练习2 (C语言代码)浏览:618 |