当前位置: 首页 > news >正文

(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())
http://www.jsqmd.com/news/120079/

相关文章:

  • 动态 IP 在爬虫、跨境电商如何避开封禁陷阱
  • nPM2100 自带标准电池模型
  • 完整教程:数据结构**排序** 超越Arrays.sort() 探索Java排序算法的奥秘与魅力
  • 在Photoshop中导出小于100KB的图片:推荐使用“存储为Web所用格式”
  • Spark与Kafka整合:构建实时数据管道完整教程
  • 非线性最优化问题求解器Ipopt介绍
  • (100分)- 表达式括号匹配(Java JS Python C)
  • npm2100 超高效升压转换器
  • 我的256天创作纪念日
  • NPM2100 电池电量估算
  • Windows系统文件inetmib1.dll丢失损坏 下载修复方法
  • java计算机毕业设计网络探店 基于大数据的美食探店可视化平台 互联网餐饮探店数据爬取与分析系统
  • 紫金桃源:不止是沈阳新市府纯别墅,更是 N 种生活的生长容器
  • PromQL 核心语法解析
  • Windows系统文件inetcomm.dll丢失损坏 下载修复方法
  • Boost电路的右半平面零点
  • 云底座 amp; 性能优化 90 天每日打卡计划
  • linux centos7.9 中文乱码
  • Tableau入门指南:大数据可视化从零到精通
  • springcloud springboot nacos版本对应 - 指南
  • 智能AI图像识别之建筑物立面缺陷识别 小区违规搭建识别 小区垃圾堆积识别 违规停车识别 建筑物墙面缺陷识别yolo数据集10314期
  • 云底座 amp; 性能优化 90 天提升 工具与学习资源清单
  • java计算机毕业设计网络流行语资源库建设及实现 网络热词共享与语义标注平台 互联网流行语知识图谱与检索系统
  • NPM2100 可控的gpio
  • .NET 文件操作中常见的内存泄漏场景梳理
  • NPM2100 LDO
  • Qt 信号槽机制的一些实现细节
  • 智慧城市与智慧校园之安防暴力检测 校园打架斗殴检测 街边暴力躁动识别 危险物品识别 智能安防 安防领域智能化 数据集第10319期 (1)
  • python题库 No.30 今日何日兮
  • AI Agent的概念形成:模拟LLM的抽象思维过程