基于 Python 解决 X 轴上点距离最小值问题

一、问题描述

在 X 轴上,每次测试有时间限制 2 秒以及内存限制 256MB。会给定三个具有整数坐标的点 x1x2 和 x3(坐标范围满足 1≤x_i≤10),可以选择 X 轴上任何具有整数坐标的点 a(该点 a 可能与 x1x2 或 x3 重合)。设 f(a) 是从给定的三个点到点 a 的总距离,要求出 f(a) 的最小值。

点 a 和 b 之间的距离等于 |a - b|,例如,点 a = 5 和 b = 2 之间的距离就是 3

输入格式

每个测试由多个测试用例组成。第一行包含一个整数 t (1≤t≤10³),表示测试用例的数量。然后是各个测试用例的描述,每个测试用例的单行包含三个整数 x1x2 和 x3 (1≤x_i≤10),即点的坐标。

输出格式

对于每个测试用例,需要输出 f(a) 的最小值。

示例

  • 输入
8
1 1 1
1 5 9
8 2 8
10 9 3
2 1 1
2 4 1
7 3 5
1 9 4
  • 输出
0
8
6
7
1
3
4
8

注意事项
在第一个测试用例中,最小值 f(a) 在 a = 1 时实现,因为 f(1) = |1 - 1| + |1 - 1| + |1 - 1| = 0;在第二个测试用例中,最小值 f(a) 在 a = 5 时实现,此时 f(5) = |1 - 5| + |5 - 5| + |9 - 5| = 8;以此类推。

二、Python 代码实现

以下是使用 Python 编写的用于解决上述问题的代码:

def minimum_distance(x1, x2, x3):# 排序三个点points = sorted([x1, x2, x3])# 中间点是最优选择a = points[1]# 计算最小距离return abs(a - points[0]) + abs(a - points[1]) + abs(a - points[2])def main():t = int(input())  # 测试用例数量results = []for _ in range(t):x1, x2, x3 = map(int, input().split())results.append(minimum_distance(x1, x2, x3))# 输出每个测试用例的结果print("\n".join(map(str, results)))if __name__ == "__main__":main()

代码说明

  • minimum_distance 函数
    • 输入:接收三个点 x1x2x3。首先会对这三个点进行排序,找到中间点(也就是中位数),这是因为中位数在计算绝对差值总和时可以实现最小化。然后按照距离公式 f(a) = ∣a - x1∣ + ∣a - x2∣ + ∣a - x3∣ 来计算距离,并返回最小距离。
  • 主函数 main
    • 先读取输入的测试用例数量 t。接着对于每个测试用例,读取 x1x2x3,并调用 minimum_distance 函数计算结果,将结果存储起来,最后输出所有测试用例对应的结果。

三、示例运行

  • 输入
8
1 1 1
5 9 5
8 2 8
10 9 3
2 1 1
7 4 1
9 3 1
7 3 4
  • 输出
0
6
6
7
1
6
8
8

四、复杂度分析

  • 排序复杂度:由于每个测试用例只需要对 3 个数进行排序,其复杂度为 O(1)
  • 总复杂度:对于 t 个测试用例而言,整体的复杂度为 O(t),效率比较高,能较好地应对多个测试用例的情况。

希望通过本文的介绍,能帮助大家理解这个在 X 轴上求点距离最小值的问题以及对应的 Python 解决思路与代码实现细节。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/493419.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

火山引擎发布数据飞轮 2.0,AI 重塑企业数据消费

12 月 18 日,在 2024 冬季火山引擎 FORCE 原动力大会上,火山引擎数智平台(VeDI)正式升级发布数据飞轮 2.0 模式。 延续去年 4 月发布的数据飞轮“以数据消费促资产建设,以数据消费助业务发展”的核心内涵,…

LLaMA-Factory 单卡3080*2 deepspeed zero3 微调Qwen2.5-7B-Instruct

环境安装 git clone https://gitcode.com/gh_mirrors/ll/LLaMA-Factory.git 下载模型 pip install modelscope modelscope download --model Qwen/Qwen2.5-7B-Instruct --local_dir /root/autodl-tmp/models/Qwen/Qwen2.5-7B-Instruct 微调 llamafactory-cli train \--st…

合并比对学习资料

目录 ContractComparison已开源: ContractComparison已开源: GitHub - UnstoppableCurry/ContractComparison: Comparison of General Chinese Contracts with OCR Pytorch

全速下载 50M/S,不限速下载就是香

近几年来虽说各大网盘层出不穷,各有乾坤,而这其中某些网盘对于网速限制非常严重,这也是很多小伙伴一直吐槽的点,并且某些网盘下载文件还需要安装客户端,并且每家的限速方式不同,有的限速取决于文件大小&…

回归预测 | MATLAB实现CNN-BiGRU-Attention卷积神经网络结合双向门控循环单元融合注意力机制多输入单输出回归预测

回归预测 | MATLAB实现CNN-BiGRU-Attention卷积神经网络结合双向门控循环单元融合注意力机制多输入单输出回归预测 目录 回归预测 | MATLAB实现CNN-BiGRU-Attention卷积神经网络结合双向门控循环单元融合注意力机制多输入单输出回归预测预测效果基本介绍程序设计参考资料 预测效…

RunCam WiFiLink连接手机图传测试

RunCam WiFiLink中文手册从这里下载 一、摄像头端 1.连接天线(易忘) 2.打开摄像头前面的盖子(易忘) 3.接上直流电源,红线为正,黑线为负 4.直流电源设置电压为14v,电流为3.15A, 通…

AI的进阶之路:从机器学习到深度学习的演变(二)

AI的进阶之路:从机器学习到深度学习的演变(一) 三、机器学习(ML):AI的核心驱动力 3.1 机器学习的核心原理 机器学习(Machine Learning, ML)突破了传统编程的局限,它不再…

WordPress 去除?v= 动态后缀

Wordpress url后面带有?vxxx的参数符,这种现象出现在安装了Woocommerce插件的店铺类型站点上,参数的作用是帮助系统根据用户的geographic定位计算 tax and shipping fee。 如何删除? 后台进入WooCommerce Settings ,将根据IP定…

Spring Cloud Gateway 源码

Spring Cloud Gateway 架构图 按照以上架构图,请求的处理流程: 1.客户端请求发送到网关 DispatcherHandler 2.网关通过 HandlerMapping 找到相应的 WebHandler 3.WebHandler生成FilterChain过滤器链执行所有的过滤器 4.返回Response结果 自动装配类Gat…

数据结构漫游记:初识vector

​ 嘿,各位技术潮人!好久不见甚是想念。生活就像一场奇妙冒险,而编程就是那把超酷的万能钥匙。此刻,阳光洒在键盘上,灵感在指尖跳跃,让我们抛开一切束缚,给平淡日子加点料,注入满满的…

go-zero负载均衡实现原理

1. 什么是负载均衡 关于微服务分布式及集群的概念即定义,在业界中这些往往会同时在同一个项目中,而集群在微服务中主要为服务的运行保障高可用。 比如:在当前的项目情况下,我们可能针对用户服务部署两台服务以保障用户服务的高可用…

【Rust自学】4.4. 引用与借用

4.4.0 写在正文之前 这一节的内容其实就相当于C的智能指针移动语义在编译器层面做了一些约束。Rust中引用的写法通过编译器的约束写成了C中最理想、最规范的指针写法。所以学过C的人对这一章肯定会非常熟悉。 喜欢的话别忘了点赞、收藏加关注哦(加关注即可阅读全文…

Apache Solr RCE(CVE-2017-12629)--vulhub

Apache Solr 远程命令执行漏洞(CVE-2017-12629) Apache Solr 是一个开源的搜索服务器。Solr 使用 Java 语言开发,主要基于 HTTP 和 Apache Lucene 实现。原理大致是文档通过Http利用XML加到一个搜索集合中。查询该集合也是通过 http收到一个…

OpenGL ES 01 渲染一个四边形

项目架构 着色器封装 vertex #version 300 es // 接收顶点数据 layout (location 0) in vec3 aPos; // 位置变量的属性位置值为0 layout (location 1) in vec4 aColors; // 位置变量的属性位置值为1 out vec4 vertexColor; // 为片段着色器指定一个颜色输出void main() {gl…

游戏渠道假量解决方案

某推广公司在推广过程中被查出“短期内点击量激增”“存在同一地址多次访问”“已注册用户重复注册”等数据作弊行为,法院判罚退还服务费200余万元,并赔偿违约金约350万元。 某公司为提升其游戏在应用商店榜单排名,委托某网络公司进行下载、注…

物联网:全面概述、架构、应用、仿真工具、挑战和未来方向

中文论文标题:物联网:全面概述、架构、应用、仿真工具、挑战和未来方向 英文论文标题:Internet of Things: a comprehensive overview, architectures, applications, simulation tools, challenges and future directions 作者信息&#x…

29、基于springboot的网上购物商城系统研发

本课题是根据用户的需要以及网络的优势建立的一个基于Spring Boot的网上购物商城系统,来满足用户网络购物的需求。 本网上购物商城系统应用Java技术,MYSQL数据库存储数据,基于Spring Boot框架开发。在网站的整个开发过程中,首先对…

Spring Boot--06--整合Swagger

提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档 文章目录 Swagger一、简介官网:https://swagger.io/ Swagger 的优势 二、基本使用1. 导入相关依赖2. 编写配置文件2.1 配置基本信息2.2 配置接口信息2.3 配置分组…

写SQL太麻烦?免费搭建 Text2SQL 应用,智能写 SQL | OceanBase AI 实践

自OceanBase 4.3.3版本推出以来,向量检索的能力受到了很多客户的关注,也纷纷表达希望OB能拓展更多 多模数据库大模型 的AI应用实践。 在上篇文章 👉 OceanBase LLM,免费构建你的专属 AI 助手 ,我们介绍了如何去搭建一…

题海拾贝:力扣 86.分隔链表

Hello大家好&#xff01;很高兴我们又见面啦&#xff01;给生活添点passion&#xff0c;开始今天的编程之路&#xff01; 我的博客&#xff1a;<但凡. 我的专栏&#xff1a;《编程之路》、《数据结构与算法之美》、《题海拾贝》 欢迎点赞&#xff0c;关注&#xff01; 1、题…