C语言题目求解

有没有好心人,编程使我痛苦😭... 有没有好心人,编程使我痛苦😭 展开
 我来答
自我编程
2020-09-02 · 科技优质答主
自我编程
采纳数:1481 获赞数:4270

向TA提问 私信TA
展开全部

程序思路:

先对总数组按年龄从大到小(相同年龄按登记号从小到大)排序。这样老年人部分就直接排序完成,并且在整个队列的前部。之后再对后半部分(非老人)按登记号从小到大再次排列。这样整个数组顺序便是题目想要的顺序。

一、初始化函数(或者说是登记函数),定义结构数组,并用随机数填充数组。(结构成员按照题意设计)。你想要手动输入1000个病人,就自己写scanf。(病人个数定义为常量MAXP,为演示显示方便常量值我设20,你改成题目的1000即可,年龄阀值也设常量,按题目值为60,可修改)。

二、两次排序函数,先调用orderByAge做总排序并获得老人个数,再调用order_notOldman对非老人排序即可。

PS:函数使用请看我的备注。函数所有异常只做返回不做处理。编程边学边用,多看多练,上手就会有乐趣。祝编程让你快来。

#include<stdio.h>

#include<string.h>

#include<stdlib.h>

#include<time.h>

#define MAXP 20//最大病人数量

#define THD 60//判断老年人的阀值,小于该值不是老人

typedef struct patient//病人结构体

{

    char pNum[13];//12位病历本号,最后一位给结束符号!

    int age;//年龄

    int pSeq;//登记顺序

}PT;

PT *init();//初始化这里用随机数生成1000名病人,成功返回结构数组,失败返回NULL

//年龄:20~90随机数。病历号格式:字母开头PSQ+1+0000~0999登记号

int showPTS(PT *pts,int len);//打印数组

int orderByAge(PT *pts,int len,int *p_len_old,int threshold);//按年龄从大到小排序,年龄相同登记号小的在前(找出老龄人数据区间)

//参数1:总的结构数组;参数2:总数组长度;参数3:接收老年人的个数(传地址);参数4:老年人阀值(本题就是60,小于阀值不是老年)

int order_notOldman(PT *pts,int len);//排序(非老人)。按登记号从小到大

int main()

{

    PT *pts=NULL;

    int len_old;

    pts=init();

    if(!orderByAge(pts,MAXP,&len_old,THD))return 1;

    printf("对总结构数组,按年龄从大到小(年龄相同按登记号从小到大)顺序排列后的数组为:\n");

    if(!showPTS(pts,MAXP))return 1;

    printf("其中老年人的个数是%d\n",len_old);

    if(!order_notOldman(&pts[len_old],MAXP-len_old)) return 1;//老人都排在前面,从&pts[len_old]地址开始就是非老人

    printf("对非老人的数组区域,按登记号从小到大顺序排列后的数组为:\n");

    if(!showPTS(pts,MAXP))return 1;

    return 0;

}

int showPTS(PT *pts,int len)

{

    int i;

    if(!pts || len==0)return 0;

    for(i=0;i<len;i++)

        printf("病历号:%s,年龄:%d,登记顺序:%d\n",pts[i].pNum,pts[i].age,pts[i].pSeq);

    return 1;

}

PT *init()

{

    static PT pts[MAXP];

    int i,age;

    char str_temp[100];

    srand(time(NULL));

    for(i=0;i<MAXP;i++)

    {

        age=rand()%71+20;

        pts[i].age=age;

        pts[i].pSeq=i;

        strcpy(pts[i].pNum,"PSQ");

        strcat(pts[i].pNum,itoa(i+10000,str_temp,10));

    }

    if(!showPTS(pts,MAXP))return NULL;

    printf("%d名病人登记完毕!\n===========================================\n",MAXP);

    return pts;

}

int orderByAge(PT *pts,int len,int *p_len_old,int threshold)

{

    int i,j;

    PT pt_temp;

    if(!pts || len==0 || !p_len_old) return 0;

    for(i=0;i<len-1;i++)

        for(j=i+1;j<len;j++)

        {

            if((pts[i].age<pts[j].age)||(pts[i].age==pts[j].age && pts[i].pSeq>pts[j].pSeq))

            {

                pt_temp=pts[i];

                pts[i]=pts[j];

                pts[j]=pt_temp;

            }

        }

    //统计老人的个数

    for(i=0;i<len;i++,*p_len_old=i)

        if(pts[i].age<threshold) break;

    return 1;

}

int order_notOldman(PT *pts,int len)

{

    int i,j;

    PT pt_temp;

    if(!pts || len==0) return 0;

    for(i=0;i<len-1;i++)

        for(j=i+1;j<len;j++)

        {

            if(pts[i].pSeq>pts[j].pSeq)

            {

                pt_temp=pts[i];

                pts[i]=pts[j];

                pts[j]=pt_temp;

            }

        }

    return 1;

}

匿名用户
2020-09-01
展开全部
哈哈哈哈哈哈哈哈,隔~
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式