找水桶

 

一.题目:

1 三人行设计了一个灌水论坛。信息学院的学生都喜欢在上面交流灌水,传说在论坛上有一个“水王”,他不但喜欢发帖,还会回复其他ID发的每个帖子。坊间风闻该“水王”发帖数目超过了帖子数目的一半。
2 如果你有一张当前论坛的帖子(包括回帖)列表,其中帖子的作者的ID也在其中,你能快速的找到这个传说中的水王吗? (参考核心代码)
3 随着论坛的发展,管理员发现水王没有了,但是统计结果表明,有三个发帖很多的ID。据统计他们的发帖数量超过了1/4,你能从发帖列表中快速找到他们吗?
 
二.设计思想
       有三个水王都超过了发帖总数的1/4,那么剩下的就不会超过1/4,
       由此可以分析,如果每次比较,去除其中不相同的三个数据,那么,跟去除找到其中超过1/2的ID数的解法是一样的。
 
三.源代码:
 #include"iostream"
 using namespace std; void Data(int l,int A[]); int main() { int l;//长度 int target[3]={0,0,0}; int ID[3]={-1,-1,-1}; cout<<"请输入帖子数量:"; cin>>l; int * shuitong=new int [l]; Data(l,shuitong); for(int i=0;i<l;i++) { if(target[0]==0 && shuitong[i]!=ID[1] && shuitong[i]!=ID[2]) { target[0]=1; ID[0]=shuitong[i]; } else if(target[1]==0 && shuitong[i]!=ID[0] && shuitong[i]!=ID[2]) { target[1]=1; ID[1]=shuitong[i]; } else if(target[2]==0 && shuitong[i]!=ID[0] && shuitong[i]!=ID[1]) { target[2]=1; ID[2]=shuitong[i]; } else if(shuitong[i]!=ID[0] && shuitong[i]!=ID[1] && shuitong[i]!=ID[2]) { target[0]--; target[1]--; target[2]--; } else if(shuitong[i]==ID[0]) { target[0]++; } else if(shuitong[i]==ID[1]) { target[1]++; } else if(shuitong[i]==ID[2]) { target[2]++; } } cout<<"水桶为:"<<ID[0]<<endl; cout<<"水桶为:"<<ID[1]<<endl; cout<<"水桶为:"<<ID[2]<<endl; return 0; } void Data(int l,int A[]) { cout<<"请输入符合条件的ID列表:"<<endl; for(int i=0;i<l;i++) { cin>>A[i]; } }
 
四、实验截图:

五、实验总结

检验一个问题是否掌握就可能就是再出一个同类型但是比原来高级的题来验证,所以我觉得我还是学的不够深入,没有理解到位。

见微知著,做学问,一定要深入,这是这次实验得到的最宝贵的教训。

其实这道题还真是跟水王问题非常像,就如同消消乐一样,就是消掉两个还是消掉三个的问题。

转载于:https://www.cnblogs.com/tangxiandi/p/4458233.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
毕设新项目-基于Java开发的智慧养老院信息管理系统源码+数据库(含vue前端源码).zip 【备注】 1、该资源内项目代码都经过测试运行成功,功能ok的情况下才上传的,请放心下载使用!有问题请及时沟通交流。 2、适用人群:计算机相关专业(如计科、信息安全、数据科学与大数据技术、人工智能、通信、物联网、自动化、电子信息等)在校学生、专业老师或者企业员工下载使用。 3、用途:项目具有较高的学习借鉴价值,不仅适用于小白学习入门进阶。也可作为毕设项目、课程设计、大作业、初期项目立项演示等。 4、如果基础还行,或热爱钻研,亦可在此项目代码基础上进行修改添加,实现其他不同功能。 欢迎下载!欢迎交流学习!不清楚的可以私信问我! 毕设新项目-基于Java开发的智慧养老院信息管理系统源码+数据库(含vue前端源码).zip毕设新项目-基于Java开发的智慧养老院信息管理系统源码+数据库(含vue前端源码).zip毕设新项目-基于Java开发的智慧养老院信息管理系统源码+数据库(含vue前端源码).zip毕设新项目-基于Java开发的智慧养老院信息管理系统源码+数据库(含vue前端源码).zip毕设新项目-基于Java开发的智慧养老院信息管理系统源码+数据库(含vue前端源码).zip毕设新项目-基于Java开发的智慧养老院信息管理系统源码+数据库(含vue前端源码).zip毕设新项目-基于Java开发的智慧养老院信息管理系统源码+数据库(含vue前端源码).zip毕设新项目-基于Java开发的智慧养老院信息管理系统源码+数据库(含vue前端源码).zip毕设新项目-基于Java开发的智慧养老院信息管理系统源码+数据库(含vue前端源码).zip
综合小区管理系统管理系统按照操作主体分为管理员和用户。管理员的功能包括报修管理、车位管理、车位分配管理、出入管理、字典管理、房屋管理、物业费缴纳管理、公告管理、物业人员投诉管理、我的私信管理、物业人员管理、用户管理、管理员管理。用户的功能包括管理部门以及部门岗位信息,管理招聘信息,培训信息,薪资信息等。该系统采用了Mysql数据库,Java语言,Spring Boot框架等技术进行编程实现。 综合小区管理系统管理系统可以提高综合小区管理系统信息管理问题的解决效率,优化综合小区管理系统信息处理流程,保证综合小区管理系统信息数据的安全,它是一个非常可靠,非常安全的应用程序。 管理员权限操作的功能包括管理公告,管理综合小区管理系统信息,包括出入管理,报修管理,报修管理,物业费缴纳等,可以管理操作员。 出入管理界面,管理员在出入管理界面中可以对界面中显示,可以对招聘信息的招聘状态进行查看,可以添加新的招聘信息等。报修管理界面,管理员在报修管理界面中查看奖罚种类信息,奖罚描述信息,新增奖惩信息等。车位管理界面,管理员在车位管理界面中新增。公告管理界面,管理员在公告管理界面查看公告的工作状态,可以对公告的数据进行导出,可以添加新公告的信息,可以编辑公告信息,删除公告信息。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值