高桥和低桥
有个脑筋急转弯是这样的:有距离很近的一高一低两座桥,两次洪水之后高桥被淹了两次,低桥却只被淹
了一次,为什么?答案是:因为低桥太低了,第一次洪水退去之后水位依然在低桥之上,所以不算“淹了两
次”。举例说明:
假定高桥和低桥的高度分别是 5 和 2,初始水位为 1
第一次洪水:水位提高到 6(两个桥都被淹),退到 2(高桥不再被淹,但低桥仍然被淹)
第二次洪水:水位提高到 8(高桥又被淹了),退到 3。
没错,文字游戏。关键在于“又”的含义。如果某次洪水退去之后一座桥仍然被淹,那么下次洪水来临水
位提高时不能算“又”淹一次。
输入n座桥的高度以及第i次洪水的涨水水位ai和退水水位bi,统计有多少座桥至少被淹了k次。初始水位为
1,且每次洪水的涨水水位一定大于上次洪水的退水水位。
输入
输入文件最多包含 25 组测试数据。每组数据第一行为三个整数n, m, k(1<=n,m,k<=105
)。第二行为n个整
数hi(2<=hi<=108
),即各个桥的高度。以下m行每行包含两个整数ai和bi(1<=bi<ai<=108
, ai>bi-1)。输入文件
不超过 5MB。
输出
对于每组数据,输出至少被淹 k 次的桥的个数。
样例输入 样例输出
2 2 2
2 5
6 2
8 3
5 3 2
2 3 4 5 6
5 3
4 2
5 2
Case 1: 1
Case 2: 3
去年省赛的一道题 ,当时用线段树没做出来 ,后来知道要离散化 ,今年再做用了离散化的线段树,结果还是超时。。。 晕死 。 后面看题解发现一种不需要数据结构的解法 非常巧妙
具体见代码吧
#include<iostream> #include<algorithm> using namespace std; #define MAXSIZE 100010 int h[MAXSIZE]; int cnt[MAXSIZE]; int n,m,k; int main() { //freopen("in.txt","r",stdin); int tcase=0; while(scanf("%d%d%d",&n,&m,&k)!=EOF) { int i; int last; memset(h,0,sizeof(h)); memset(cnt,0,sizeof(cnt)); for(i=0;i<n;i++) { scanf("%d",&h[i]); } sort(h,h+n); last=1; for(i=0;i<m;i++) { int a,b; scanf("%d%d",&a,&b); int tmpa=upper_bound(h,h+n,a)-h;//返回第一个大于a的下标 若不存在则返回0 if(h[tmpa]>a) tmpa--; int tmpb=upper_bound(h,h+n,last)-h; if(tmpb==last) tmpb++; cnt[tmpb]++; cnt[tmpa+1]--; last=b; } for(i=1;i<n;i++) { cnt[i]+=cnt[i-1]; } int ans=0; for(i=0;i<n;i++) { if(cnt[i]>=k) ans++; } printf("Case %d: %d\n",++tcase,ans); } return 0; }
相关推荐
3. 马鞍的历史演变:马鞍的发展经历了从无鞍骑马,到铺设皮质垫子,再到低桥鞍和高桥鞍的过程。秦俑坑中的骑兵马鞍属于低桥鞍的初期形式,鞍桥极低,缺乏防止向前滑动的胸带。西汉时期,鞍桥逐渐增高,到了东汉则...
【桥梁工程安全施工方案】 桥梁工程是交通基础设施建设的重要...总之,桥梁工程安全施工方案强调了从人员培训、设备安全、施工过程控制到特殊工况下的应对措施,全方位确保施工安全,以实现高效、低风险的工程实施。
例如,高桥和隧道区域在冬季可能因低温而更容易结冰,需要在这些位置设置遥感式路面状态和能见度检测器。同时,根据海拔和气候特征,在典型区域设立全要素气象检测器,与摄像机配合,以应对异常气候条件下的交通安全...
cole_02_0507
内容概要:南京邮电大学工程硕士研究的无线传感器网络路由技术。通过对无线传感器网络路由协议的历史和研究现状进行了详细探讨,着重介绍了SPIN、LEACH、TEEN、pEGASIS等常见协议的特点、优势与局限性。文中分析了现有路由协议中的能量管理和网络覆盖问题,并提出了一种结合最大覆盖模型的改进型能量LEACH协议来应对这些问题。该研究旨在提高无线传感网络能量效率和覆盖效果,从而拓展其在各行业尤其是环境监测和军事安全领域的大规模应用。 适合人群:本篇文章主要面向具有无线传感网路研究背景或对此有兴趣的研究人员、工程师和技术爱好者,特别是在能源消耗控制上有较高需求的应用开发者。 使用场景及目标:①帮助理解和选择合适的无线传感器网络路由技术;②指导开发新路由协议时关注的关键要素;③为企业实施物联网相关项目提供理论支撑。 其他说明:文章强调了优化算法对于改善系统性能的重要性,并展示了具体的实施方案。通过仿真实验对不同协议的效果进行了验证,体现了科学研究的严谨态度与实践导向。
【东海期货-2025研报】东海贵金属周度策略:金价高位回落,阶段性回调趋势初现.pdf
【资源介绍】 1、该资源包括项目的全部源码,下载可以直接使用! 2、本项目适合作为计算机、数学、电子信息等专业的课程设计、期末大作业和毕设项目,也可以作为小白实战演练和初期项目立项演示的重要参考借鉴资料。 3、本资源作为“学习资料”如果需要实现其他功能,需要能看懂代码,并且热爱钻研和多多调试实践。 图像数据处理工具+数据(帮助用户快速划分数据集并增强图像数据集。通过自动化数据处理流程,简化了深度学习项目的数据准备工作).zip 图像数据处理工具+数据(帮助用户快速划分数据集并增强图像数据集。通过自动化数据处理流程,简化了深度学习项目的数据准备工作).zip 图像数据处理工具+数据(帮助用户快速划分数据集并增强图像数据集。通过自动化数据处理流程,简化了深度学习项目的数据准备工作).zip 图像数据处理工具+数据(帮助用户快速划分数据集并增强图像数据集。通过自动化数据处理流程,简化了深度学习项目的数据准备工作).zip 图像数据处理工具+数据(帮助用户快速划分数据集并增强图像数据集。通过自动化数据处理流程,简化了深度学习项目的数据准备工作).zip 图像数据处理工具+数据(帮助用户快速划分数据集并增强图像数据集。通过自动化数据处理流程,简化了深度学习项目的数据准备工作).zip 图像数据处理工具+数据(帮助用户快速划分数据集并增强图像数据集。通过自动化数据处理流程,简化了深度学习项目的数据准备工作).zip 图像数据处理工具+数据(帮助用户快速划分数据集并增强图像数据集。通过自动化数据处理流程,简化了深度学习项目的数据准备工作).zip
diminico_02_0709
agenda_3cd_01_0716
目录: 第1章 Linux命令入门及VIM编辑器 第2章Python基础 第3章Python面向对象编程 第4章数据结构与算法 第5章UDP与TCP通信 第6章多进程编程 第7章多线程编程 第8章协程 第9章正则表达式 第10章 Http协议 Web服务器并发服务器 第11章网络通信过程 第12章 Python提高1 第13章 Python提高2 第14章 Mysq|基本使用 第15章 Mysq|查询 第16章Mysql与Python交互 第17章Mysql高级 第18章WSGI-miniWeb框架 第19章闭包装饰器 第20章 mini-web框架 添加路由-MySQL功能 第21章 mini-web框架 添加log日志路由支持正则 第22章元类与ORM-面向接口编程
diminico_02_1108
基于人工智能大模型技术的果蔬农技知识智能问答系统.pdf
diminico_02_0307
dawe_3cd_01_0717
anslow_3ck_01_0319
C#全自动多线程上位机源码编程:替代传统PLC触摸屏、以太网通信,强大功能多级页签,支持西门子PLC和OPC,安装KepserverEx5,链接其他数据库,C#多线程自动化工控屏幕上位机源码编程系统:功能强大,多级页签,通信灵活,兼容多种配置与数据库连接,C#全自动多线程上位机源码编程 0, 纯源代码。 1, 替代传统plc搭载的触摸屏。 2, 工控屏幕一体机直接和plc通信。 3, 功能强大,多级页签。 4, 可以自由设定串口或以太网通信。 5, 主页。 6, 报警页。 7, 手动调试页。 8, 参数设定页。 9, 历史查询页。 10,系统设定页。 11, 赠送所有控件。 12,使用的西门子Plc。 13,注册opcdaauto.dll组件,用于使用opc。 15,安装kepserverEx5。 16,可以链接其他数据库。 ,核心关键词: C#; 全自动多线程; 上位机源码编程; 纯源代码; PLC替代; 通信; 强大功能; 多级页签; 串口或以太网通信; 主页; 报警页; 手动调试页; 参数设定页; 历史查询页; 系统设定页; 控件赠送; 西门子PLC; OPC
内容概要:本文详细介绍了移动应用开发的全过程,从创意构思和需求分析开始,依次阐述了原型设计、技术选型、前后端开发、测试优化、上线准备到最后的推广和后续维护,帮助读者深入了解和掌握各个环节的要点和最佳实践,特别注重实际操作中的问题和解决方法。文章不仅涵盖技术层面的内容,还包括市场营销和社会影响等方面的探讨。 适合人群:移动应用开发初学者和有一定经验的开发者,想要了解移动应用从构想直到推向市场全部过程的专业人士。 使用场景及目标:指导新创企业和个体开发者从零开始制作自己的应用程序,提供系统的理论知识以及实用技能指导。 阅读建议:本文适合分章节细读,尤其对于每个关键阶段,可以结合具体的案例研究深入理解;在实践应用时应注意参考文中提到的实际开发中容易碰到的问题及其解决方案。
axios-min.js
Rust语言教程:从入门到进阶 Rust是一门注重性能、内存安全以及并发的系统编程语言。它被设计用来替代C和C++,同时提供更高的安全性和更好的并发支持。本教程将引导你从Rust的基础语法开始,逐步掌握到更高级的概念。 一、Rust入门 1. Rust安装 工具链安装:通过rustup安装Rust工具链,它包含Rust编译器、Cargo包管理器以及标准库文档。 验证安装:在终端运行rustc --version和cargo --version来检查Rust和Cargo是否成功安装。 2. Hello, World! 创建一个新的Rust项目:cargo new hello_world --bin。 进入项目目录:cd hello_world。 编辑srcmain.rs文件,添加fn main() { println!(Hello, World!); }。 编译并运行项目:cargo run。 3. Rust基础语法 变量:使用let关键字声明变量,默认情况下变量是不可变的(immutable)。 数据类型:整数(i32, u32等)、浮点数(f32, f64)、布尔值(bool)、字
anslow_05_0109