我比小白还小白 2022-01-28 16:19 采纳率: 87.5%
浏览 31
已结题

(C语言)我的代码有几种情况不对,能帮我看看错哪里了嘛

问题:
选夫婿^_^
倾国倾城的大家闺秀潘小姐要选夫婿啦!武林中各门各派,武林外各大户人家,闻讯纷纷前来,强势围观。前来参与竞选的男生藏龙卧虎,gaoshou云集,才子遍布,shuaige纷纭,更不乏富二代,官二代,可谓声势空前。
每个人参与竞选的shuaige除了进行一段激情洋溢的求婚演讲以外,还要报上自己姓名、身高和体重,以及个人简历。最后再进行文武选拔,最后夺魁者方能得到潘小姐的芳心。
潘小姐不爱名利,只看人,第一关就是身高和体重要合格,即必须在其要求的范围内,否则直接排除在外,不允许参加下一轮的选拔。
作为一个程序员,你没有钱也没有权,擅长的也就是编程了。潘小姐也发现了这一点,所以把首轮根据身高体重进行选拔的任务交给了你,如果完成的好,你可以直接进入下一轮选拔,你笑了。

输入格式:
潘小姐给你了所有报名男生的信息。输入数据的第一行是一个正整数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>
#include<string.h> 
struct zxc{
    char z[200];
    int x;
    int c;
};
struct zxc m[20000];
int main(){
    int z,x,c,v,q,w,e,r,n=0;
    char b[200];
    scanf("%d",&z);
    for(x=0;x<z;x++)
    scanf("%s %d %d",m[x].z,&m[x].x,&m[x].c);
    scanf("%d %d %d %d",&q,&w,&e,&r);
    for(x=0;x<z;x++){
        for(c=x;c<z;c++){
            if(m[x].x>m[c].x){
                strcpy(b,m[x].z);
                strcpy(m[x].z,m[c].z);
                strcpy(m[c].z,b);
                
                v=m[x].x;
                m[x].x=m[c].x;
                m[c].x=v;
                
                v=m[x].c;
                m[x].c=m[c].c;
                m[c].c=v;
            }
        }
    }             //按身高排序
        for(x=0;x<z;x++){
        for(c=x;c<z;c++){
            if(m[x].c>m[c].c){
                strcpy(b,m[x].z);
                strcpy(m[x].z,m[c].z);
                strcpy(m[c].z,b);
                
                v=m[x].x;
                m[x].x=m[c].x;
                m[c].x=v;
                
                v=m[x].c;
                m[x].c=m[c].c;
                m[c].c=v;
            }
        }
    }            //按体重排序,若身高体重相同则顺序即为输入顺序
    for(x=0;x<z;x++)
        if((m[x].x>=q&&m[x].x<=w)&&(m[x].c>=e&&m[x].c<=r))
        {
            printf("%s %d %d\n",m[x].z,m[x].x,m[x].c);
            n=1;
        }         //符合要求的输出
    if(n==0) printf("NO");  //没有符合要求的输出NO
    return 0;
}

  • 写回答

2条回答 默认 最新

  • _GX_ 2022-01-28 20:11
    关注
    #include <stdio.h>
    #include <string.h>
    
    #define N 1000
    
    struct Person
    {
        char name[20];
        int height;
        int weight;
    };
    
    struct Person persons[N];
    
    void swap(struct Person *p1, struct Person *p2)
    {
        struct Person p = *p1;
        *p1 = *p2;
        *p2 = p;
    }
    
    int compare(struct Person *p1, struct Person *p2)
    {
        if (p1->height > p2->height)
            return 1;
        if (p1->height < p2->height)
            return 0;
        return p2->weight < p1->weight;
    }
    
    void sort(struct Person *p, int n)
    {
        for (int i = 0; i < n - 1; i++)
        {
            for (int j = 0; j < n - i - 1; j++)
            {
                if (compare(&p[j], &p[j + 1]))
                    swap(&p[j], &p[j + 1]);
            }
        }
    }
    
    int main()
    {
        int n, a, b, c, d;
        scanf("%d", &n);
        for (int i = 0; i < n; i++)
            scanf("%s%d%d", persons[i].name, &persons[i].height, &persons[i].weight);
        scanf("%d%d%d%d", &a, &b, &c, &d);
        sort(persons, n);
        int found = 0;
        for (int i = 0; i < n; i++)
        {
            struct Person *p = persons + i;
            if (p->height >= a && p->height <= b && p->weight >= c && p->weight <= d) {
                printf("%s %d %d\n", p->name, p->height, p->weight);
                found = 1;
            }
        }
        if (!found)
            printf("NO");
        return 0;
    }
    
    $ cat test.txt
    8
    武大郎 70 40
    西门庆 180 70
    李逵 160 150
    燕青 175 69
    鲁智深 180 100
    武松 180 75
    小泉纯一狼 30 20
    孙二娘 169 60
    165 190 60 90
    $ gcc -Wall main.c
    $ cat test.txt | ./a.out
    孙二娘 169 60
    燕青 175 69
    西门庆 180 70
    武松 180 75
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

问题事件

  • 系统已结题 2月5日
  • 已采纳回答 1月28日
  • 创建了问题 1月28日

悬赏问题

  • ¥20 搭建pt1000三线制高精度测温电路
  • ¥15 使用Jdk8自带的算法,和Jdk11自带的加密结果会一样吗,不一样的话有什么解决方案,Jdk不能升级的情况
  • ¥15 画两个图 python或R
  • ¥15 在线请求openmv与pixhawk 实现实时目标跟踪的具体通讯方法
  • ¥15 八路抢答器设计出现故障
  • ¥15 opencv 无法读取视频
  • ¥15 按键修改电子时钟,C51单片机
  • ¥60 Java中实现如何实现张量类,并用于图像处理(不运用其他科学计算库和图像处理库))
  • ¥20 5037端口被adb自己占了
  • ¥15 python:excel数据写入多个对应word文档