动态地构造一个数组,用于存放学生的信息,然后按照学生信息中的分数从高到低排序,依次输出学生信息。
#include<stdio.h>
#include<stdlib.h>
struct Student
{
char name[20] ;
int age ;
float score ;
};
//这里在书上是是先声明自定义函数,再写主函数,最后再写自定义函数,但我个人比较喜欢先写自定义函数,这样就不用多花时间去写那个声明了
void InputStudent ( int n , struct Student *p )
{
for ( int i = 0 ; i < n ; i ++ )
{
printf("请输入第%d学生的信息:\n",i+1);
printf("name:");
scanf("%s",(p+i)->name);//name是数组名,本身就是数组的第一个元素的地址,所以前面不需要加&
printf("age:");
scanf("%d",&(p+i)->age );//age是int型的,所以前面必须加上取地质符&
printf ("score:");
scanf("%f",&(p+i)->score );
}
printf("\n");
return ;
}
//按学生的成绩降序冒泡排序
void BubbleSort ( int n , struct Student *p )
{
struct Student buf ;
int i , j ;
for ( i = 0 ; i < n - 1 ; i ++ )
{
for ( j = 0 ; j < n - 1 - i ; j ++ )
{
if ( (p+j)->score < (p+j+1)->score )
{
buf = *(p+j) ;
*(p+j) = *(p+j+1) ;
*(p+j+1) = buf ;
}
}
}
return ;
}
void OutputStudent ( int n , struct Student const *p )
{
int i ;
printf("按照成绩高低输入学生信息:\n\n");
for ( i = 0 ; i < n ; i ++ )
{
printf("第%d个学生的信息是:\n",i+1);
printf("name : %s\n",(p+i)->name );
printf("age : %d\n",(p+i)->age);
printf("%f",(p+i)->score );
}
return ;
}
int main (void)
{
int n ;
struct Student *p = NULL ;//NULL的意思是空的意思,表示指针指向一个空指针,*p = 0,可以让他随时指向其他地址,此时这里用于存放内存的首地址
printf("请输入学生的个数:n = ");//确定动态数组的长度
scanf ("%d",&n);
p = malloc( n * sizeof*p ) ;//动态构造一维数组,此时sizeof就可以看出*p相比类型
//sizeof的后面可以紧跟类型,也可以直接跟变量名。如果是变量名,那么就表示该变量在内存中所占的字节数。所以*p是int型的,那么sizeof*p就表示int型变量在内存中所占的字节数
InputStudent( n , p ) ;
BubbleSort ( n , p ) ;
OutputStudent ( n , p );
return 0;
}
这是我在Xcode上输出的结果,应该是编译器的原因,所以在最后输出的时候没有输出汉语,其他的没有问题,正常输出