news 2026/5/26 2:09:30

(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/5/26 4:00:28

多智能体协同系统

多智能体协同系统的核心概念 多智能体协同系统&#xff08;Multi-Agent Systems, MAS&#xff09;通过多个自主智能体的交互实现复杂任务&#xff0c;广泛应用于机器人协作、自动驾驶、游戏AI等领域。核心特性包括分布式决策、通信协议、任务分配与冲突解决。典型应用案例 1. 无…

作者头像 李华
网站建设 2026/5/26 4:02:24

多角度关于人的本质的论述,你怎么思考?

第六章&#xff1a;多角度关于人的本质的论述人的本质&#xff0c;人和动物的区别是什么&#xff0c;此文可以参考。这个问题很深奥&#xff0c;历来人类试图回答。比如中国古代对于人&#xff0c;有善恶之分&#xff0c;但这显然不具有说服力。以下是马克思哲学关于人本质的思…

作者头像 李华
网站建设 2026/5/25 6:50:10

Flutter 实现一个容器内部元素可平移、缩放和旋转等功能(六)

Flutter 实现一个容器内部元素可平移、缩放和旋转等功能&#xff08;六&#xff09; Flutter: 3.35.6 前面有人提到在元素内部的那块判断怎么那么写的&#xff0c;看来对知识渴望的小伙伴还是有&#xff0c;这样挺好的。不至于说牢记部分知识&#xff0c;只需要大致了解一下有…

作者头像 李华
网站建设 2026/5/26 3:59:07

python作业4

a 56 b -18# 1. 按位与(&)&#xff1a;对应位都为1则为1&#xff0c;否则为0 # 56: 00111000 # -18补码: 11101110 # 按位与: 00101000 → 十进制40 bit_and a & b print(f"按位与(&): {a} & {b} {bit_and}")# 2. 按位或(|)&#xff1a;对应位有…

作者头像 李华
网站建设 2026/5/26 2:43:31

今天教大家免费使用先进的AI大模型,非常详细收藏这一篇就够了

为什么要使用ai模型&#xff1f; 用好ai可以解决你想做的事情比如数据录入、数据整理、数据分析、数据报告等等问题。只要你想好规则&#xff0c;他都可以给你生成&#xff0c;而且你要担心数据泄露问题&#xff0c;完全可以让他给你生成一个离线的app或者exe程序或者前端程序&…

作者头像 李华
网站建设 2026/5/26 2:43:29

边缘AI与端云协同架构

边缘AI与端云协同架构概述 边缘AI将人工智能模型部署在边缘设备&#xff08;如手机、传感器、嵌入式设备&#xff09;上&#xff0c;实现本地实时处理&#xff1b;端云协同通过边缘与云计算的协作&#xff0c;平衡计算负载、隐私与延迟。典型应用包括智能家居、工业检测、自动驾…

作者头像 李华