構造に関する最初の連絡先は、実験室での評価後に調査せずに、ケースにリストされているコードに従って自分で編集しました。
トピック:
2。指定されたデータを格納するための適切な構造を作成し、指定された操作を完了するために対応する関数を記述します。
(1)次のデータを
順番にデポジットします:名前、学生番号、性別順序
Xiao Ming20201034男性
1Xiao Hong20201057女性
5Li Hua20201042男性3
小明 20201034 男 1
Xiaohong20201057男性3Li
Hua 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;
}
はるかに良い。
最終評価は成功しました。