关于结构体的初次接触是在一次实验室考核再没学习的情况下照着案列的代码对应所给题目自己编的
题目:
2、创建一个恰当的结构体存储指定数据,并且编写相应的函数完成指定操作。
(1)依次存入如下数据:
姓名 学号 性别 次序
小明 20201034 男 1
小红 20201057 女 5
李华 20201042 男 3
小明 20201034 男 1
小红 20201057 男 3
李华 20201042 男 5
(2)编写函数ShowInfo,输出所有信息。
(3)编写函数SortShow,使得存储数据以学号由大到小进行输出(需使用一种排序算法);
我的代码(有点瑕疵):
#include <stdio.h>
struct stu
{
char name[3];
int number[3];
char n[3];
int x[3];
};
int main()
{
int i,j;
int num;
struct stu st[3]={
{"xiaoming",20201034,"man",1},
{"xiaohong",20201057,"woman",5},
{"lihua",20201042,"man",3}
};
struct stu temp;
num=3;
for(i=0;i<num;i++)
{
for(j=0;j<num-i-1;j++)
{
if(st[j].number[3]<st[j+1].number[3])
{
temp=st[j];
st[j]=st[j+1];
st[j+1]=temp;
}
}
}
printf("姓名\t学号\t性别\t次序\n");
for(i=0;i<num;i++)
{
printf("%s\t%d\t%s\t%d\n",
st[i].name,st[i].number,st[i].n,st[i].x);
}
}
运行结果:
服了。。。。。。
经改正后:
#include<stdio.h>
#include<malloc.h>
typedef struct Stu
{
char name[5];
int id;
char sex[1];
int num;
}STU;
void init(STU *stu)
{
int i;
STU *s = stu;
for(i=0;i<3;i++)
{
scanf("%s",s[i].name);
scanf("%d",&s[i].id);
scanf("%s",s[i].sex);
scanf("%d",&s[i].num);
}
}
void Show(STU *stu)
{
int i;
STU *s = stu;
for(i=0;i<3;i++,s++)
{
printf("%s %d %s %d\n",s->name,s->id,s->sex,s->num);
}
}
void SortShow(STU *stu)
{
int i,j,flag,flagsort[3]={0,1,2};
STU *s = stu;
for(i=0;i<2;i++)
{
for(j=0;j<2-i;j++)
{
if(s[flagsort[j]].id < s[flagsort[j+1]].id)
{
flag = flagsort[j];
flagsort[j]=flagsort[j+1] ;
flagsort[j+1] = flag ;
}
}
}
for(i=0;i<3;i++)
{
printf("%s %d %s %d\n",s[flagsort[i]].name,s[flagsort[i]].id,s[flagsort[i]].sex,s[flagsort[i]].num);
}
}
int main (void)
{
STU s[3];
printf("Please input message: \n");
init(s);
printf("Show ran over :\n");
Show(s);
printf("SortShow ran over :\n");
SortShow(s);
return 0;
}
完善许多了。
最终考核成功入围。