OpenJudge计算概论-比饭量【枚举法、信息数字化】

简介: /*====================================================================== 比饭量 总时间限制: 1000ms 内存限制: 65536kB 描述 3个人比饭量,每人说了两句话: A说:B比我吃的多,C和我吃的一样多 B说:A比我吃的多,A也比C吃的多 C说:我比B吃得多,B比A吃的多。
/*======================================================================
比饭量
总时间限制: 1000ms 内存限制: 65536kB
描述
3个人比饭量,每人说了两句话:
A说:B比我吃的多,C和我吃的一样多
B说:A比我吃的多,A也比C吃的多
C说:我比B吃得多,B比A吃的多。
事实上,饭量和正确断言的个数是反序的关系。
请编程按饭量的大小输出3个人的顺序。

输入
无输入
输出
按照饭量大小输出3人顺序,比如:
ABC
样例输入
无
样例输出
无

解析:这个题目在OpenJudge提交时,题目意思不清晰,应该按饭量从小到大的顺序输出字母 
用三重for循环枚举所有可能的解
对每一种可能的解计算每一个人正确断言的数量 
然后把饭量、正确断言数量分别打包到数组(把人对应的编号一起封装)
对两个数组进行排序(一个由大到小,另一个由小到大) 
检测两个数组每一个元素对应的人名字是否一致,若所有人的名字一致,得到一个可行解。输出
继续循环寻找下一个可行解 
========================================================================*/
 1 #include<iostream>
 2 using namespace std;
 3 struct person
 4 {
 5     int n;//饭量或者断言数量
 6     char name;//名字 
 7 };
 8 int main()
 9 {
10     int a,b,c;//三者的范围都是1~3,这里把a、b、c的值看作他们的饭量(不一定要用1~3,只要能区分出三个数的大小就行了)
11     //当然,也可以换一下思路,用a、b、c表示饭量排名
12     int A,B,C;//表示断言正确的数量 
13     struct person x[3],y[3],t;
14     int i,j,flag;
15     for(a=0;a<3;a++)
16     {
17         for(b=0;b<3;b++)
18         {
19             for(c=0;c<3;c++)
20             {
21                 A=(b>a)+(c==a);
22                 B=(a>b)+(a>c);
23                 C=(c>b)+(b>a);
24                 /*假如三个人的饭量不会相等、三个人的断言正确数量也不会相等,
25                 下面就判断a+A、b+B、c+C是否都相等,都等于3就行了。
26                 但是这个题目,三个人饭量可能相等,断言正确数量也可能一样,必需用其他方式*/ 
27                 //下面把a、b、c、A、B、C分别放到数组x、y当中。 然后对x、y数组进行排序
28                 x[0].n=a;x[0].name='A';
29                 x[1].n=b;x[1].name='B'; 
30                 x[2].n=c;x[2].name='C';
31                 y[0].n=A;y[0].name='A';
32                 y[1].n=B;y[1].name='B'; 
33                 y[2].n=C;y[2].name='C';
34                 //对x数组按元素的饭量从大到小排序,对y数组按元素的断言正确数量从小到大排序
35                 for(i=1;i<3;i++)
36                 {
37                     flag=1;
38                     for(j=0;j<3-i;j++) 
39                     {
40                         if(x[j].n<x[j+1].n)
41                         {
42                             flag=0;
43                             t=x[j];
44                             x[j]=x[j+1];
45                             x[j+1]=t;
46                         }
47                     }
48                     if(flag) break; //if(flag==1) break;
49                 }
50                 
51                 for(i=1;i<3;i++)
52                 {
53                     flag=1;
54                     for(j=0;j<3-i;j++) 
55                     {
56                         if(y[j].n>y[j+1].n)
57                         {
58                             flag=0;
59                             t=y[j];
60                             y[j]=y[j+1];
61                             y[j+1]=t;
62                         }
63                     }
64                     if(flag) break; //if(flag==1) break;
65                 }
66                 //从头到尾检查x和y数组每一个元素对应的是否是同一个人 
67                 for(i=0;i<3;i++)
68                 {
69                     if(x[i].name!=y[i].name) break;
70                 }
71                 if(i==3)
72                 {//输出结果 
73                     for(i=2;i>=0;i--)
74                         cout<<x[i].name;
75                     cout<<endl;
76                 }
77             }
78         }
79     }
80     return 0;
81 }

 

相关文章
|
4月前
|
运维 供应链 安全
SaaS模式云HIS数字化医院信息系统源码
云HIS具有可扩展、易共享、易协同、低成本、体验号、更便捷、易维护的优势,重新定义了数字化医院信息系统,实现数字化医院信息系统的转型升级。云 HIS 系统具有功能完善,涵盖临床各业务部门,采集、抽提、汇总、存贮、展现所有的临床诊疗资料(包括:数据、文本、图形、图像、声音等),是医疗机构实现临床信息化的理想信息平台。
74 1
|
4月前
|
存储 索引 Windows
PACS影像信息数字化存储系统源码,C/S架构的医学影像系统源码
全院影像设备联网与影像信息数字化存储,建立涵盖全院的PACS/RIS系统,实现从预约、登记、分诊、排队叫号、检查、诊断阅片、报告发布、自助胶片打印等流程化管理。 PACS系统应用在医院影像科时,它直接与CT、MR、ECT、DSA和DR等提供DICOM标准图像的医学设备进行软硬对接。该系统应用在超声、内窥镜、病理等科室时,提供视频、普通图片的医学设备进行软硬对接。检查结果以DICOM、BMP、JPG等多种格式进行长期保存,形成影像历史、诊断历史。这些历史数据可供医生重复调阅,作为编写诊断报告的重要参考。
PACS影像信息数字化存储系统源码,C/S架构的医学影像系统源码
|
4月前
|
弹性计算 资源调度 Cloud Native
融合云计算与分布式系统架构:拥抱数字化时代的技术进化
在当今数字化时代,云计算和分布式系统架构成为企业转型的关键工具。本文将探讨这两项技术的融合,以及它们在提升效率、降低成本和增强可扩展性方面的潜力。通过深入分析云计算和分布式系统架构的原理和优势,我们将看到如何利用这些技术推动企业的数字化转型。
|
4月前
|
存储 监控 Oracle
医院数字化LIS(检验信息系统)源码
医院数字化LIS(检验信息系统)源码
44 0
|
10月前
|
存储 监控 数据挖掘
C#医院数字化LIS(检验信息系统)源码
LIS系统能够自动处理大量的医学数据,包括样本采集、样本处理、检测分析、报告生成等。它能够快速、准确地进行化验检测,提高医院的运营效率。LIS系统还提供了丰富的数据分析功能,能够对医院化验室的业务流程进行全面、细致的监控。
110 0
|
人工智能 弹性计算 Cloud Native
阿里云计算巢加速器:让优秀的软件生于云、长于云—入选企业深度访谈—精准医疗迎数字化新机遇,百奥利盟携手阿里云为创新生物药提速上市
阿里云计算巢加速器:让优秀的软件生于云、长于云—入选企业深度访谈—精准医疗迎数字化新机遇,百奥利盟携手阿里云为创新生物药提速上市
514 0
|
人工智能 运维 Kubernetes
阿里云计算巢加速器:让优秀的软件生于云、长于云—入选企业深度访谈—工程师背后的工程师,KodeRover携手阿里云帮助企业构建数字化基建
阿里云计算巢加速器:让优秀的软件生于云、长于云—入选企业深度访谈—工程师背后的工程师,KodeRover携手阿里云帮助企业构建数字化基建
207 0
|
安全 网络协议
中国互联网络信息中心助力中小企业数字化转型
中国互联网络信息中心助力中小企业数字化转型——“互联网基础资源赋能百万中小企业数字化行动”正式启动
521 0
|
4天前
|
Cloud Native 持续交付 云计算
云原生技术:企业数字化转型的新引擎
在当今数字化浪潮中,云原生技术作为推动企业创新与转型的关键力量,正引领着一场技术革命。本文深入探讨了云原生的核心概念、技术特点及其对企业IT架构和运营模式的深远影响。通过分析云原生在实际案例中的应用,揭示了其如何助力企业实现敏捷开发、弹性扩展和成本优化等目标。同时,本文也展望了云原生技术的未来发展趋势,强调了掌握这一技术对于企业保持竞争力的重要性。
22 10
|
2天前
|
存储 安全 网络安全
网络安全与信息安全:构建安全防线的多维策略在当今数字化时代,网络安全已成为维护个人隐私、企业机密和国家安全的关键要素。本文旨在探讨网络安全漏洞的本质、加密技术的重要性以及提升公众安全意识的必要性,以期为构建更加坚固的网络环境提供参考。
本文聚焦于网络安全领域的核心议题,包括网络安全漏洞的现状与应对、加密技术的发展与应用,以及安全意识的培养与实践。通过分析真实案例,揭示网络安全威胁的多样性与复杂性,强调综合防护策略的重要性。不同于传统摘要,本文将直接深入核心内容,以简洁明了的方式概述各章节要点,旨在迅速吸引读者兴趣,引导其进一步探索全文。

热门文章

最新文章