代码如下:
#include
#include
#include
#define maxn 99
struct student{
char name[20];
int grade;
} stu[maxn];
int cmp(const void*a, const void*b)
{
return ((struct student*)a)->grade - ((struct student*)b)->grade;
}
int main(void)
{
puts("Please input the name and the grade:");
int i = 0;
while(scanf("%s %d", stu[i].name, &stu[i].grade) == 2)
{
getchar();
++i;
}
qsort(stu,i, sizeof(struct student), cmp);
int j;
for (j = 0; j printf("%s : %d\n", stu[j].name, stu[j].grade);
puts("Please input the grade you want to search:");
float temp = 0;
while (scanf("%d", &temp))
{
struct student *p;
p =(struct student*) bsearch(&temp, stu, i, sizeof(struct student), cmp);
if (p)
printf("%s : %d\n", p->name, p->grade);
else
puts("not found!");
}
return 0;
}
输出如下:
bsearch(&temp, stu, i, sizeof(struct student), cmp);
temp和stu不是一个类型吧,stu里面是结构体,temp是数
版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。