OpenJudge计算概论-分配病房

简介: /*===================================== 分配病房 总时间限制: 1000ms 内存限制: 65536kB 描述 某个科室的病房分为重症和普通,只有当病人的疾病严重程度超过了入住重症病房的最低严重值,才可以安排入住重症病房。
/*=====================================
分配病房
总时间限制: 1000ms 内存限制: 65536kB
描述
某个科室的病房分为重症和普通,只有当病人的疾病严重程度超过了入住重症病房的最低严重值,才可以安排入住重症病房。 
现在要求设计一个程序,给病人安排好病房。疾病的严重程度用0到10来表示,0表示小毛病,10表示非常严重。
输入
第一行输入病人的个数m(m < 50),以及安排住入重症病房的最低严重值a
紧接着m行,每行表示病人编号(三个位,用0补齐)及其疾病的严重程度(浮点数,1位小数)。
每个病人的疾病严重程度都不一样。
输出
要求按照病人的严重程度输出住在重症病房里的病人的编号
注意:
如果当前所有病人的严重程度并不满足住在重症病房里,则输出“None.”(不包括引号)
样例输入
    10   7.55
    006   6.5
    005   8.0
    004   3.5
    009   8.5
    011   7.0
    043   9.5
    003   5.0
    103   6.0
    112   4.0
    118   9.0
样例输出
    043  9.5
    118  9.0
    009  8.5

解析:用结构体存储每个人的信息。
输入时检测是否重症病人(需要保存其信息到数组);
输入完后对数组排序
然后输出即可。 ======================================
*/
#include<stdio.h>
struct person
{
    int no;//病人的编号 
    float num;//病人病情严重程度 
};
int main()
{
    struct person p[55];//表示重症病人的结构体数组 
    int m;//m个病人 
    float a;//入住重症病房的最低严重值 
    int i;//循环变量 
    int n;//临时变量,表示当前输入的病人的编号 
    float t;//临时变量,表示当前输入的病人的严重值 
    int len=0;//表示当前已经遇到的重症病人的人数 
    int j,flag;
    struct person temp;
    freopen("5.in","r",stdin);
    scanf("%d%f",&m,&a);
    for(i=0;i<m;i++)//读入m个人的信息并确定是否重症病人,即:是否需保存其信息 
    {
        scanf("%d%f",&n,&t);//读入病人的编号和严重值 
        if(t>a)
        {
            p[len].no=n;
            p[len].num=t;
            len++;
        }
    }
     if(len==0)//假如没有重症病人 
    {
        printf("None.\n");
        return 0;
    }
    for(i=1;i<len;i++)//对重症病人按严重值排序 ,冒泡算法 
    {
        flag=1;
        for(j=0;j<len-i;j++)
        {
            if(p[j].num<p[j+1].num) 
            { 
                flag=0;
                temp=p[j]; 
                p[j]=p[j+1]; 
                p[j+1]=temp; 
            }
        }
        if(flag)  break;  //if(flag==1)  break;
    }
    for(i=0;i<len;i++)//按重症病人的严重值由大到小输出他们的信息。 
    {
        printf("%03d %.1f\n",p[i].no,p[i].num);
    }
    return 0;
}

 

相关文章
|
机器学习/深度学习 Windows
Openjudge计算概论-角谷猜想
/*===================================== 角谷猜想 总时间限制: 1000ms 内存限制: 65536kB 描述 所谓角谷猜想,是指对于任意一个正整数,如果是奇数,则乘3加1,如果是偶数,则除以2,得到的结果再按照上述规则重复处理,最终总能够得到1。
925 0
OpenJudge计算概论-字符串最大跨距
/*====================================================================== 字符串最大跨距 总时间限制: 1000ms 内存限制: 65536kB 描述 有三个字符串S,S1,S2,其中,S长度不超过300,S1和S2的长度不超过10,想检测S1和S2是否同时在S中出现,且S1位于S2的左边,并在 S中互不交叉(即,S1的右边界点在S2的左边界点的左侧)。
1354 0
|
人工智能
OpenJudge计算概论-寻找山顶
/*===================================== 寻找山顶 总时间限制: 1000ms 内存限制: 65536kB 描述 在一个m×n的山地上,已知每个地块的平均高程,请求出所有山顶所在的地块(所谓山顶,就是其地块平均高程不比其上下左右相邻的四个地块每个地块的平均高程小的地方)。
859 0
|
Java
OpenJudge计算概论-配对碱基链
/*===================================== 配对碱基链 总时间限制: 1000ms 内存限制: 65536kB 描述 脱氧核糖核酸(DNA)由两条互补的碱基链以双螺旋的方式结合而成。
1300 0
|
ice
OpenJudge计算概论-文字排版
/*====================================================================== 文字排版 总时间限制: 1000ms 内存限制: 65536kB 描述 给一段英文短文,单词之间以空格分隔(每个单词应包括其前后紧邻的标点符号)。
861 0
|
人工智能
OpenJudge计算概论-计算鞍点
/*======================================================================== 计算鞍点 总时间限制: 1000ms 内存限制: 65536kB 描述 输入一个二维 (5*5)数组,每行只有一个最大值,每列只有一个最小值。
1198 0
|
存储 机器学习/深度学习
OpenJudge计算概论-错误探测
/*======================================================================== 错误探测 总时间限制: 1000ms 内存限制: 65536kB 描述 给出由0和1组成的矩阵,如果矩阵的每一行和每一列的1的数量都是偶数,则认为符合条件。
1214 0
|
人工智能 算法 Java
OpenJudge计算概论-计算书费
/*============================================== 计算书费 总时间限制: 1000ms 内存限制: 65536kB 描述 下面是一个图书的单价表: 计算概论 28.9 元/本 数据结构与算法 32.7 元/本 数字逻辑 45.6元/本 C++程序设计教程 78 元/本 人工智能 35 元/本 计算机体系结构 86.2 元/本 编译原理 27.8元/本 操作系统 43 元/本 计算机网络 56 元/本 JAVA程序设计 65 元/本 给定每种图书购买的数量,编程计算应付的总费用。
1242 0
|
存储 BI
OpenJudge计算概论-最长平台
/*=========================================================== 最长平台 总时间限制: 1000ms 内存限制: 65536kB 描述 已知一个已经从小到大排序的数组,这个数组的一个平台(Plateau)就是连续的一串值相同的元素,并且这一串元素不能再延伸。
1018 0
OpenJudge计算概论-求平均年龄
/*============================================== 求平均年龄 总时间限制: 1000ms 内存限制: 65536kB 描述 班上有学生若干名,给出每名学生的年龄(整数),求班上所有学生的平均年龄,保留到小数点后两位。
1387 0