c语言结构体练习

例题1

SDUT某实验室集训队的选拔又要开始了,集训队需要根据参加者的分数排名来决定谁能够进入集训队。 先要求你写一个自动排名的程序,根据每一个参与选拔的同学的分数进行排名,集训队需要根据大家的分数排名来决定谁能够进入集训队。
你能完成这个程序么?

输入格式:

输入的第一行为n ( 0<n<=50) ;

之后给出n 行,每行为一个人名和ta所得到的分数。保证没有相同的分数。
人名为英文单词,长度不超过10。

输出格式:

输出为n行,每行一个人名与他的得分。每一行最后没有多余的空格。

具体输出格式见样例。

输入样例:

3
Dan 10
John 50
Danny 30

输出样例:

John 50
Danny 30
Dan 10

 

#include<stdio.h>
#include<string.h>
int main(){
    int n;
    scanf("%d",&n);
    char names[n][11];//注意这里一定最少是11,因为字符串最后结束符,且题目中长度是10
    int scores[n];
    if(0<n&&n<=50){
    int i,j;
        for(i=0;i<n;i++){
            scanf("%s %d",names[i],&scores[i]);
        }
        for(i=0;i<n-1;i++){
            for(j=0;j<n-i-1;j++){
                if(scores[j]<scores[j+1]){
                    char temp[11];
                    int t;
                    strcpy(temp,names[j]);
                    strcpy(names[j],names[j+1]);
                    strcpy(names[j+1],temp);
                    t=scores[j];
                    scores[j]=scores[j+1];
                    scores[j+1]=t;
                }
            }
        }
        for(i=0;i<n;i++){
            printf("%s %d",names[i],scores[i]);
            if(i<n-1)printf("\n");
        }
    }
    return 0;
}

《程序设计基础》组织了一次程序设计竞赛,比赛完后需要产生一个最终排名,排名按照题数多少来决定。但是有太多的队伍参与,手动计算排名已经不能满足比赛的需求。现在有一份名单记录各个队伍的ID和做出的题目数,需要你写一个程序,产生最终的排名。

为了简化题目,这里的排名规则为:做出题目数量多的队伍排在前面,如果题数相等,保持输入时的相对顺序不要改变。

输入格式:

第一行有一个正整数N(1 < N ≤ 10000),表示队伍数量。

接下来N 行包含两个整数,1 ≤ ID ≤ 10^7, 0 ≤ M ≤ 100。ID为队伍的编号,M为做出的题数。

输出格式:

输出包含N行;

第i行有两个整数,ID和M表示排在第i位的队伍的ID和做出的题数。

输入样例:

8
1 2
16 3
11 2
20 3
3 5
26 4
7 1
22 4

输出样例:

3 5
26 4
22 4
16 3
20 3
1 2
11 2
7 1

 这个题目同样也是要求冒泡排序,可是不同的是,数组下标是来当作索引的进行排序的,而我们又需要定义一个结构体类型,不同于上一个题目,所以为了进行交换,我们可以另外创建一个结构体变量来承接,作为中转站

#include<stdio.h>
struct team
{
	int id,number;
}a;
int main()
{
	int n;
    scanf("%d",&n);
    struct team fp[n];
	for(int i=0;i<n;i++)	scanf("%d %d",&fp[i].id,&fp[i].number);	
	for(int i=0;i<n-1;i++)
	{
		for(int j=0;j<n-i-1;j++)
		{
			if(fp[j].number<fp[j+1].number)
			{
				a=fp[j];
				fp[j]=fp[j+1];
				fp[j+1]=a;
			}
		}
	}
	for(int i=0;i<n;i++)	printf("%d %d\n",fp[i].id,fp[i].number);
}

 

 

倾国倾城的大家闺秀潘小姐要选夫婿啦!武林中各门各派,武林外各大户人家,闻讯纷纷前来,强势围观。前来参与竞选的男生藏龙卧虎,高手云集,才子遍布,帅哥纷纭,更不乏富二代,官二代,可谓声势空前。

1569.jpg

每个人参与竞选的帅哥除了进行一段激情洋溢的求婚演讲以外,还要报上自己姓名、身高和体重,以及个人简历。最后再进行文武选拔,最后夺魁者方能得到潘小姐的芳心。

潘小姐不爱名利,只看人,第一关就是身高和体重要合格,即必须在其要求的范围内,否则直接排除在外,不允许参加下一轮的选拔。

作为一个程序员,你没有钱也没有权,擅长的也就是编程了。潘小姐也发现了这一点,所以把首轮根据身高体重进行选拔的任务交给了你,如果完成的好,你可以直接进入下一轮选拔,你笑了。

输入格式:

潘小姐给你了所有报名男生的信息。

输入数据的第一行是一个正整数N (0 < N < 1000)。

之后N 行数据,每行包含三部分,用空格隔开。第一部分是报名者的姓名name(长度小于20的字符串),然后是整数身高h(0 < h < 300),第三部分是整数体重w (0 < w < 200)。

最后一行是四个整数a,b,c,d.表示身高的合格范围是[a,b],体重的合格范围是[c,d](0 < a < b < 200, 0 < c < d < 300)。

输出格式:

你需要把合格的男生信息按照身高从低到高输出,格式跟输入一样,也是每行三个信息,共N行,如果身高相同则按体重从轻到重输出,若没有合格人选则输出No,具体格式见样例。

输入样例:

8
武大郎 70 40
西门庆 180 70
李逵 160 150
燕青 175 69
鲁智深 180 100
武松 180 75
小泉纯一狼 30 20
孙二娘 169 60
165 190 60 90

 

输出样例:

孙二娘 169 60
燕青 175 69
西门庆 180 70
武松 180 75

 我们最终目的是将合格的,从低到高输出

两个问题

合格

升序输出

为了检查合格同时满足升序输出,所以我们可以先进性排序,之后再这个顺序下循环检查是否合格

而排序同上一篇一样,有先后顺序,先比较的是身高,记得这里是直接赋值结构体,不用分别赋值成员属性,然后当身高一样,没法再比较的时候,再进行体重的判断

#include<stdio.h>
struct bro{
    char name[10];
    int tall,weight;
    int f;
    };
int main(){
    int n;
    scanf("%d",&n);
    struct bro m[n],temp;
    int i,j,a,b,c,d;
    for(i=0;i<n;i++)scanf("%s %d %d",m[i].name,&m[i].tall,&m[i].weight);
 scanf("%d%d%d%d",&a,&b,&c,&d);
    for(j=0;j<n-1;j++){
        for(i=0;i<n-j-1;i++){
            if(m[i].tall>m[i+1].tall){
                temp=m[i];
                m[i]=m[i+1];
                m[i+1]=temp;
            }
            else if(m[i].tall==m[i+1].tall){
           if(m[i].weight>m[i+1].weight){
                temp=m[i];
                m[i]=m[i+1];
                m[i+1]=temp;
            }
            }
        }
    }
    int k=1;
    for(i=0;i<n;i++)
	{
	
		if((m[i].tall>=a&&m[i].tall<=b)&&(m[i].weight>=c&&m[i].weight<=d))
		{
			printf("%s %d %d\n",m[i].name,m[i].tall,m[i].weight);
			k=0;//标记有没有合格的人
		}
    }
    if(k==1)printf("No");
    return 0;
}

然后最后在输出这方面,是输出及格的人,所以我们只需要判断后直接输出即可,不用加上标志位什么的

给出n件物品,每件物品有质量和价格两种属性。你要做的是按质量升序排序,若质量相同则按价格降序排序。

输入格式:

第一行输入一个正整数n(1<=n && n <= 100),代表有n件物品。

接下来的一行有n个正整数Wi(1<= Wi && Wi <= 10000),代表每件物品的质量。

再接下来的一行有n个正整数Pi(1 <= Pi && Pi <= 10000),代表每件物品的价格。

输出格式:

输出n行,每行两个数Wi,Pi。顺序为题目描述所要求。

输入样例:

3
1 2 2
3 2 3

输出样例:

1 3
2 3
2 2

 

#include<stdio.h>
struct thing1{
    int price,quality;
};
int main(){
    int n;
    scanf("%d",&n);
    if(1<=n&&n<=100){
    struct thing1 t1[n],a;
    int i,j;
    for(i=0;i<n;i++){
        scanf("%d",&t1[i].quality);
    }
     for(i=0;i<n;i++){
        scanf("%d",&t1[i].price);
    }
    
for(i=0;i<n-1;i++){
    for(j=0;j<n-i-1;j++){
        if(t1[j].quality>t1[j+1].quality){
            a=t1[j];
            t1[j]=t1[j+1];
            t1[j+1]=a;
        }
        else if(t1[j].quality==t1[j+1].quality){
            if(t1[j].price<t1[j+1].price){
            a=t1[j];
            t1[j]=t1[j+1];
            t1[j+1]=a;
            }
        }
    }
}
    for(i=0;i<n;i++){
        printf("%d %d",t1[i].quality,t1[i].price);
        if(i<n-1)printf("\n");
    }
    }
    return 0;
}

 同上一个题目一样,都是先比较一项进行冒泡排序,再比较一项进行冒泡排序,中间赋值的过程是创建一个结构体变量来作为中间变量进行赋值,赋值给结构体

完结撒花

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值