news 2026/4/23 19:12:59

(100分)- ABR 车路协同场景(Java JS Python)

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
(100分)- ABR 车路协同场景(Java JS Python)

(100分)- ABR 车路协同场景(Java & JS & Python)

题目描述

数轴×有两个点的序列 A={A1, A2, …, Am}和 B={B1, B2, ..., Bn}, Ai 和 Bj 均为正整数, A、 B 已经从小到大排好序, A、 B 均肯定不为空,

给定一个距离 R(正整数),列出同时满足如下条件的所有(Ai, Bj)数对

条件:

  1. Ai <= Bj
  2. Ai,Bj 距离小于等于 R,但如果 Ai 找不到 R 范围内的 Bj,则列出距它最近的 1 个 Bj,当然此种情况仍然要满足 1,

但如果仍然找不到,就丢弃 Ai。

原型:

车路协同场景,一条路上发生了有很多事件( A),要通过很多路测设备( B)广播给路上的车,需要给每个事件找到一个合适的路测设备去发送广播消息。

输入描述

按照人易读的格式输入一行数据,参见输入样例,其中“ ABR={, }”中的每个字符都是关键分割符,输入中无空格,其他均为任意正整数,

输入 A 和 B 已经排好序, A 和 B 的大小不超过 50,正整数范围不会超过 65535。

输出描述z

( Ai,Bj)数对序列,排列顺序满足序列中前面的 Ax<=后面的 Ay,前面的 Bx<=后面的 By,

因为输入 A 和 B 已经排好序,所以实际上输出结果不用特意排序,排序不是考察点。

用例
输入A={1,3,5},B={2,4,6},R=1
输出(1,2)(3,4)(5,6)
说明
题目解析

首先,输入中有效数据的获取,我使用了正则

const regExp = /A\=\{(.+)\}\,B\=\{(.+)\}\,R\=(.+)/;

其中有三个捕获组,分别捕获出1,3,5和2,4,6以及1

然后我们就可以通过一些简单的字符串操作得到A,B,R数据了。

得到A、B、R后,我们只要双重for,外层遍历A,内层遍历B,然后找满足A[i] + R = B[j]的数据,当然在找的过程中,需要记录第一个比A[i]大的B[j1],因为要防止找不到满足A[i] + R = B[j]的数据时,可以输出一个和A[i]最近的B[j1]

Ai,Bj 距离小于等于 R,但如果 Ai 找不到 R 范围内的 Bj,则列出距它最近的 1 个 Bj,当然此种情况仍然要满足 1,


本题要返回的 (Ai,Bj) 数对需要满足下面条件

  1. Ai <= Bj
  2. Ai,Bj 距离小于等于 R,但如果 Ai 找不到 R 范围内的 Bj,则列出距它最近的 1 个 Bj,当然此种情况仍然要满足 1

关于其中第2个条件

  • 如果对于Ai,存在多个Bj,使其满足Ai <= Bj 且 Bj - Ai <= R,则应该全部输出。
  • 如果对于Ai,不存在Bj 满足Ai <= Bj 且 Bj - Ai <= R,则应该进一步检查是否存在Bj > Ai,如果存在,则输出这些Bj中最小的那个和Ai组成的数对。
JavaScript算法源码
/* JavaScript Node ACM模式 控制台输入获取 */ const readline = require("readline"); const rl = readline.createInterface({ input: process.stdin, output: process.stdout, }); rl.on("line", (line) => { const regExp = /A\=\{(.+)\}\,B\=\{(.+)\}\,R\=(.+)/; let [_, A, B, R] = regExp.exec(line); A = A.split(",").map(Number); B = B.split(",").map(Number); R = parseInt(R); console.log(getResult(A, B, R)); }); function getResult(A, B, R) { const ans = []; for (let a of A) { let cnt = 0; for (let b of B) { if (b < a) continue; if (b - a <= R || cnt == 0) { ans.push(`(${a},${b})`); cnt++; } else { break; } } } return ans.join(""); }
Java算法源码
import java.util.Arrays; import java.util.Scanner; import java.util.regex.Matcher; import java.util.regex.Pattern; public class Main { public static void main(String[] args) { Scanner sc = new Scanner(System.in); String s = sc.nextLine(); Matcher m = Pattern.compile("A=\\{(.+)},B=\\{(.+)},R=(.+)").matcher(s); if (m.matches()) { int[] A = Arrays.stream(m.group(1).split(",")).mapToInt(Integer::parseInt).toArray(); int[] B = Arrays.stream(m.group(2).split(",")).mapToInt(Integer::parseInt).toArray(); Integer R = Integer.parseInt(m.group(3)); System.out.println(getResult(A, B, R)); } } public static String getResult(int[] A, int[] B, Integer R) { StringBuilder sb = new StringBuilder(); for (int a : A) { int cnt = 0; for (int b : B) { if (b < a) continue; if (b - a <= R || cnt == 0) { sb.append("(").append(a).append(",").append(b).append(")"); cnt++; } else { break; } } } return sb.toString(); } }
Python算法源码
import re # 输入获取 s = input() tmp = re.compile(r"A=\{(.+)},B=\{(.+)},R=(.+)").search(s) A = list(map(int, tmp.group(1).split(","))) B = list(map(int, tmp.group(2).split(","))) R = int(tmp.group(3)) # 算法入口 def getResult(): ans = [] for a in A: cnt = 0 for b in B: if b < a: continue if b - a <= R or cnt == 0: ans.append(f"({a},{b})") cnt += 1 else: break return "".join(ans) # 算法调用 print(getResult())
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/23 14:44:14

AI原生开发范式

AI原生开发范式的核心概念 AI原生开发范式&#xff08;AI-Native Development&#xff09;指以AI为核心构建应用程序的设计方法&#xff0c;其特点包括数据驱动、模型即服务&#xff08;MaaS&#xff09;、自动化工作流和持续学习。与传统开发相比&#xff0c;AI原生应用将机器…

作者头像 李华
网站建设 2026/4/23 13:02:27

鸿蒙破晓:一场技术与人才突围的生态远征

转载自&#xff1a;万能的大熊2025年末的深圳夜空被电子屏幕点亮&#xff0c;华为旗舰店内陈列的Mate 80 Pro max超透亮灵珑屏上&#xff0c;HarmonyOS 6系统正流畅运行微信鸿蒙版的原相机调用功能&#xff0c;指尖轻触可实现夜景照片的毫秒级处理&#xff1b;展区另一侧的折叠…

作者头像 李华
网站建设 2026/4/23 12:12:32

当一部手机定价近两万:三星三折叠价格和功能如何匹配?

在高端智能手机市场&#xff0c;每当价格标签触及五位数&#xff0c;总会引发一场关于价值对等的辩论。近日&#xff0c;三星一款新形态折叠屏手机上市的信息&#xff0c;再次将这一话题推向焦点。512GB版本19999.00元&#xff0c;1TB版本21999.00元&#xff0c;面对这样的标价…

作者头像 李华
网站建设 2026/4/23 12:22:26

三星最新款手机推荐:Galaxy Z TriFold三折叠形态的体验革命

“一款手机能当工作站与创作台&#xff1f;三星最新三折叠旗舰给出新答案&#xff01;”三星Galaxy Z TriFold作为最新旗舰&#xff0c;以三折叠设计重构移动设备体验&#xff0c;成为高端用户的焦点之选。本文从技术革新、场景适配等维度&#xff0c;深度解析这款机型的核心价…

作者头像 李华
网站建设 2026/4/23 10:44:52

一文读懂大模型微调:从全参数到LoRA,打造你的专属AI专家

本文详细介绍了三种大模型适配技术&#xff1a;全参数微调&#xff08;性能最佳但资源消耗大&#xff09;、LoRA微调&#xff08;轻量高效&#xff09;和RAG&#xff08;通过外部知识库增强&#xff09;。针对不同场景提供技术选型指南&#xff0c;强调没有"最优解"只…

作者头像 李华