c++写:题目描述: 小A是一个美食爱好者。市里新开了一家美食街,这当然是小A不能错过的盛宴啦。 美食街是一条笔直的直线,在街道的不同的点上,有着不同种类的美食,第i个美食店的位置为xi,美食品种编号为pi。 这么多种美食让小A眼花缭乱,小A想要品尝所有品种的美食,又想走最少的路。 请编程帮助小A计算,他品尝所有品种的美食,要走的最短路程有多长? 输入 第1行有一个整数N,表示街道上美食店的总数量; 接下来N行,每行有2个整数xi和pi,分别代表了不同美食店的位置,以及这个美食店的美食品种。 测试数据保证同一个位置xi,只会开一家美食店。 输出 输出一个整数,代表小A要走的最短路程; 路程的计算方式为:如果从xi点到xj(xi≤xj)包含了所有品种的美食,那么路程长度=|xi−xj|。 样例 输入复制 7 2 2 1 3 5 2 4 1 6 3 10 2 8 1 输出复制 2 说明 【样例解释】 样例中xi可选取区间[4,6],可以包含所有的美食品种。 【数据范围】 对于20%的数据,10≤n≤20; 对于另外40%的数据,10≤n≤1000; 对于100%的数据,1≤n≤50000,1≤xi,pi≤109;

时间: 2024-04-18 21:23:51 浏览: 35
```cpp #include <iostream> #include <vector> #include <map> <algorithm> using namespace std; int main() { int N; cin >> N; // 使用map来记录每种美食的最后一个位置 map<int, int> lastPosition; for (int i = 0; i < N; i++) { int xi, pi; cin >> xi >> pi; lastPosition[pi] = xi; // 更新美食品种pi的最后一个位置 } // 找到最小的位置差 int minDistance = INT_MAX; int prevPosition = 0; // 上一个位置 for (auto it = lastPosition.begin(); it != lastPosition.end(); it++) { int currentPosition = it->second; // 计算当前位置与上一个位置之间的距离 int distance = currentPosition - prevPosition; minDistance = min(minDistance, distance); prevPosition = currentPosition; // 更新上一个位置 } cout << minDistance << endl; return 0; } ``` 这个程序首先读取输入的美食店数量N,然后使用map数据结构来记录每种美食的最后一个位置。接下来,遍历输入的每个美食店,更新每种美食的最后一个位置。 然后,通过遍历map,计算相邻两个美食品种的位置差,找到最小的位置差,即为小A要走的最短路程。 最后,输出最短路程。

相关推荐

c++写题目描述 小 � A 是一个美食爱好者。市里新开了一家美食街,这当然是小 � A 不能错过的盛宴啦。 美食街是一条笔直的直线,在街道的不同的点上,有着不同种类的美食,第 � i 个美食店的位置为 � � x i ​ ,美食品种编号为 � � p i ​ 。 这么多种美食让小 � A 眼花缭乱,小 � A 想要品尝所有品种的美食,又想走最少的路。 请编程帮助小 � A 计算,他品尝所有品种的美食,要走的最短路程有多长? 输入 第 1 1 行有一个整数 � N ,表示街道上美食店的总数量; 接下来 � N 行,每行有 2 2 个整数 � � x i ​ 和 � � p i ​ ,分别代表了不同美食店的位置,以及这个美食店的美食品种。 测试数据保证同一个位置 � � x i ​ ,只会开一家美食店。 输出 输出一个整数,代表小 � A 要走的最短路程; 路程的计算方式为:如果从 � � x i ​ 点到 � � x j ​ ( � � ≤ � � x i ​ ≤x j ​ )包含了所有品种的美食,那么路程长度 = � � − � � =x j ​ −x i ​ 。 样例 输入复制 7 2 2 1 3 5 2 4 1 6 3 10 2 8 1 输出复制 2 说明 【样例解释】 样例中 � � x i ​ 可选取区间 [ 4 , 6 ] [4,6],可以包含所有的美食品种。 【数据范围】 对于 20 % 20% 的数据, 10 ≤ � ≤ 20 10≤n≤20; 对于另外 40 % 40% 的数据, 10 ≤ � ≤ 1000 10≤n≤1000; 对于 100 % 100% 的数据, 1 ≤ � ≤ 50000 1≤n≤50000, 1 ≤ � � , � � ≤ 1 0 9 1≤x i ​ ,p i ​ ≤10 9 ;

最新推荐

recommend-type

C++ boost::asio编程-异步TCP详解及实例代码

主要介绍了C++ boost::asio编程-异步TCP详解及实例代码的相关资料,需要的朋友可以参考下
recommend-type

C++ boost::asio编程-同步TCP详解及实例代码

主要介绍了C++ boost::asio编程-同步TCP详解及实例代码的相关资料,需要的朋友可以参考下
recommend-type

C++ 中boost::share_ptr智能指针的使用方法

主要介绍了C++ 中boost::share_ptr智能指针的使用方法的相关资料,希望通过本文能帮助到大家,需要的朋友可以参考下
recommend-type

C++标准库:std_set作为一个有序集合

std::set作为标准库的一个关联容器,实现内部元素进行了排序,使用这特性可以对一组元素进行插入排序。std::set最初的设计是完成数学中“集合”的概念,它提供的接口也是如此。
recommend-type

C++面向对象实现五子棋小游戏

本文介绍了如何运用面向对象思想进行五子棋游戏的设计与开发,与面向过程程序设计比较,面向对象程序设计更易于实现对现实世界的描述,提高软件的扩展性和可维护性。附上最终的程序源码,推荐给大家,有需要的小伙伴...
recommend-type

zigbee-cluster-library-specification

最新的zigbee-cluster-library-specification说明文档。
recommend-type

管理建模和仿真的文件

管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire
recommend-type

优化MATLAB分段函数绘制:提升效率,绘制更快速

![优化MATLAB分段函数绘制:提升效率,绘制更快速](https://ucc.alicdn.com/pic/developer-ecology/666d2a4198c6409c9694db36397539c1.png?x-oss-process=image/resize,s_500,m_lfit) # 1. MATLAB分段函数绘制概述** 分段函数绘制是一种常用的技术,用于可视化不同区间内具有不同数学表达式的函数。在MATLAB中,分段函数可以通过使用if-else语句或switch-case语句来实现。 **绘制过程** MATLAB分段函数绘制的过程通常包括以下步骤: 1.
recommend-type

SDN如何实现简易防火墙

SDN可以通过控制器来实现简易防火墙。具体步骤如下: 1. 定义防火墙规则:在控制器上定义防火墙规则,例如禁止某些IP地址或端口访问,或者只允许来自特定IP地址或端口的流量通过。 2. 获取流量信息:SDN交换机会将流量信息发送给控制器。控制器可以根据防火墙规则对流量进行过滤。 3. 过滤流量:控制器根据防火墙规则对流量进行过滤,满足规则的流量可以通过,不满足规则的流量则被阻止。 4. 配置交换机:控制器根据防火墙规则配置交换机,只允许通过满足规则的流量,不满足规则的流量则被阻止。 需要注意的是,这种简易防火墙并不能完全保护网络安全,只能起到一定的防护作用,对于更严格的安全要求,需要
recommend-type

JSBSim Reference Manual

JSBSim参考手册,其中包含JSBSim简介,JSBSim配置文件xml的编写语法,编程手册以及一些应用实例等。其中有部分内容还没有写完,估计有生之年很难看到完整版了,但是内容还是很有参考价值的。