構造初心者

構造に関する最初の連絡先は、実験室での評価後に調査せずに、ケースにリストされているコードに従って自分で編集しました。

トピック:
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;
}

はるかに良い。

最終評価は成功しました。

おすすめ

転載: blog.csdn.net/yooppa/article/details/112406957