(新卷,100分)- 恢复数字序列(Java JS Python)

(新卷,100分)- 恢复数字序列(Java & JS & Python)

题目描述

对于一个连续正整数组成的序列,可以将其拼接成一个字符串,再将字符串里的部分字符打乱顺序。如序列8 9 10 11 12,拼接成的字符串为89101112,打乱一部分字符后得到90811211,原来的正整数10就被拆成了0和1。

现给定一个按如上规则得到的打乱字符的字符串,请将其还原成连续正整数序列,并输出序列中最小的数字。

输入描述

输入一行,为打乱字符的字符串和正整数序列的长度,两者间用空格分隔,字符串长度不超过200,正整数不超过1000,保证输入可以还原成唯一序列。

输出描述

输出一个数字,为序列中最小的数字。

用例
输入19801211 5
输出8
说明
题目解析

本题“打乱字符的字符串”的是由“连续正整数序列”组成的,而题目又说:正整数不超过1000

因此,本题可以考虑使用滑动窗口,在1~1000整数范围内滑动,滑窗窗口的长度为输入的“连续正整数序列”的长度。

我们只需要统计“打乱字符的字符串”中各字符的数量,以及滑窗中各字符的数量,如果所有字符对于的数量都相同,那么说明对应滑窗就是一个符合要求的连续正整数数列,我们只需要取滑窗第一个数值即可。

滑窗在运动过程中,可以利用差异比较,即当前滑窗相交于上一个滑窗,失去了一个数字,新增了一个数字,当前滑窗只需要针对失去数字和新增数字的字符做数量修改即可。

Java算法源码
import java.util.HashMap; import java.util.Scanner; public class Main { public static void main(String[] args) { Scanner sc = new Scanner(System.in); String s = sc.next(); // 打乱字符的字符串 int k = sc.nextInt(); // 连续正整数序列的长度 System.out.println(getResult(s, k)); } public static int getResult(String s, int k) { // base:统计打乱字符的字符串中 各字符的数量 HashMap<Character, Integer> base = new HashMap<>(); for (int i = 0; i < s.length(); i++) { char c = s.charAt(i); base.put(c, base.getOrDefault(c, 0) + 1); } // 初始滑窗(长度k)中各字符的数量 HashMap<Character, Integer> count = new HashMap<>(); for (int i = 1; i <= k; i++) { countNumChar(i + "", count, true); } // 比较滑窗各字符数量,和base统计的各字符数量是否一致,若一致,则说明初始滑窗就是一个符合要求的连续整数数列,该数列的最小值为1 if (cmp(base, count)) return 1; // 否则继续尝试后续滑窗,注意题目说正整数不超过1000,因此我们可以尝试连续正整数序列取值范围就是1~1000 for (int i = 2; i <= 1000 - k + 1; i++) { // 相较于上一个滑窗失去的数字 String remove = i - 1 + ""; countNumChar(remove, count, false); // 相较于上一个滑窗新增的数字 String add = i + k - 1 + ""; countNumChar(add, count, true); // 比较 if (cmp(base, count)) return i; } return -1; // 题目说存在唯一的序列满足条件,因此这里返回语句是走不到的 } public static void countNumChar(String num, HashMap<Character, Integer> count, boolean isAdd) { for (int j = 0; j < num.length(); j++) { char c = num.charAt(j); count.put(c, count.getOrDefault(c, 0) + (isAdd ? 1 : -1)); } } public static boolean cmp(HashMap<Character, Integer> base, HashMap<Character, Integer> count) { for (Character c : base.keySet()) { if (!count.containsKey(c) || count.get(c) - base.get(c) != 0) { return false; } } return true; } }
JS算法源码
/* JavaScript Node ACM模式 控制台输入获取 */ const readline = require("readline"); const rl = readline.createInterface({ input: process.stdin, output: process.stdout, }); rl.on("line", (line) => { const [s, k] = line.split(" "); console.log(getResult(s, Number(k))); }); /** * * @param {*} s 打乱字符的字符串 * @param {*} k 连续正整数序列的长度 */ function getResult(s, k) { // base:统计打乱字符的字符串中 各字符的数量 const base = {}; for (let c of s) { base[c] = (base[c] ?? 0) + 1; } // 初始滑窗(长度k)中各字符的数量 const count = {}; for (let i = 1; i <= k; i++) { countNumChar(i + "", count, true); } // 比较滑窗各字符数量,和base统计的各字符数量是否一致,若一致,则说明初始滑窗就是一个符合要求的连续整数数列,该数列的最小值为1 if (cmp(base, count)) return 1; // 否则继续尝试后续滑窗,注意题目说正整数不超过1000,因此我们可以尝试连续正整数序列取值范围就是1~1000 for (let i = 2; i <= 1000 - k + 1; i++) { // 相较于上一个滑窗失去的数字 const remove = i - 1 + ""; countNumChar(remove, count, false); // 相较于上一个滑窗新增的数字 const add = i + k - 1 + ""; countNumChar(add, count, true); // 比较 if (cmp(base, count)) return i; } return -1; // 题目说存在唯一的序列满足条件,因此这里返回语句是走不到的 } function countNumChar(num, count, isAdd) { for (let c of num) { count[c] = (count[c] ?? 0) + (isAdd ? 1 : -1); } } function cmp(base, count) { for (let c in base) { if (count[c] === undefined || count[c] != base[c]) { return false; } } return true; }
Python算法源码
# 输入获取 s, k = input().split() k = int(k) def cmp(base, count): for c in base: if count.get(c) is None or count[c] != base[c]: return False return True def countNumChar(num, count, isAdd): for c in num: count[c] = count.get(c, 0) + (1 if isAdd else -1) # 算法入口 def getResult(): # base:统计打乱字符的字符串中 各字符的数量 base = {} for c in s: base[c] = base.get(c, 0) + 1 # 初始滑窗(长度k)中各字符的数量 count = {} for i in range(1, k + 1): countNumChar(str(i), count, True) # 比较滑窗各字符数量,和base统计的各字符数量是否一致,若一致,则说明初始滑窗就是一个符合要求的连续整数数列,该数列的最小值为1 if cmp(base, count): return 1 # 否则继续尝试后续滑窗,注意题目说正整数不超过1000,因此我们可以尝试连续正整数序列取值范围就是1~1000 for i in range(2, 1000 - k + 2): # 相较于上一个滑窗失去的数字 remove = str(i - 1) countNumChar(remove, count, False) # 相较于上一个滑窗新增的数字 add = str(i + k - 1) countNumChar(add, count, True) # 比较 if cmp(base, count): return i # 题目说存在唯一的序列满足条件,因此这里返回语句是走不到的 return -1 # 调用算法 print(getResult())

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

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

相关文章

配电网故障重构+智能算法Matlab代码

✅作者简介&#xff1a;热爱科研的Matlab仿真开发者&#xff0c;擅长数据处理、建模仿真、程序设计、完整代码获取、论文复现及科研仿真。 &#x1f34e; 往期回顾关注个人主页&#xff1a;Matlab科研工作室 &#x1f447; 关注我领取海量matlab电子书和数学建模资料 &#x1…

Java毕设选题推荐:基于SpringBoot+Vue的旅游管理系统门票购买、酒店信息、房间预订、行程工具等功能【附源码、mysql、文档、调试+代码讲解+全bao等】

博主介绍&#xff1a;✌️码农一枚 &#xff0c;专注于大学生项目实战开发、讲解和毕业&#x1f6a2;文撰写修改等。全栈领域优质创作者&#xff0c;博客之星、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java、小程序技术领域和毕业项目实战 ✌️技术范围&#xff1a;&am…

【双层模型】分布式光伏储能系统的优化配置方法Matlab代码

✅作者简介&#xff1a;热爱科研的Matlab仿真开发者&#xff0c;擅长数据处理、建模仿真、程序设计、完整代码获取、论文复现及科研仿真。 &#x1f34e; 往期回顾关注个人主页&#xff1a;Matlab科研工作室 &#x1f447; 关注我领取海量matlab电子书和数学建模资料 &#x1…

基于GA_BFGS算法的配电网故障恢复性重构研究附Matlab代码

✅作者简介&#xff1a;热爱科研的Matlab仿真开发者&#xff0c;擅长数据处理、建模仿真、程序设计、完整代码获取、论文复现及科研仿真。 &#x1f34e; 往期回顾关注个人主页&#xff1a;Matlab科研工作室 &#x1f447; 关注我领取海量matlab电子书和数学建模资料 &#x1…

从零开始掌握消息队列

前言在当今的分布式系统架构中&#xff0c;消息队列已经成为不可或缺的核心组件。Apache Kafka作为一款高吞吐量、低延迟的分布式消息系统&#xff0c;被广泛应用于大数据处理、日志收集、流式处理等场景。一、Kafka是什么&#xff1f;Apache Kafka是一个分布式流处理平台&…

计算机毕设 java 基于智能推荐的宠物之家网站设计与实现 Java 智能推荐宠物服务平台设计与开发 基于 Java 的宠物之家智能推荐系统研发

计算机毕设 java 基于智能推荐的宠物之家网站设计与实现 f48cc9&#xff08;配套有源码 程序 mysql 数据库 论文&#xff09;本套源码可以先看具体功能演示视频领取&#xff0c;文末有联 xi 可分享随着互联网科技的进步和人们生活水平的提高&#xff0c;宠物数量快速增加&#…

大数据运营中的常见陷阱与规避策略:资深专家经验分享

大数据运营中的常见陷阱与规避策略&#xff1a;资深专家经验分享关键词&#xff1a;大数据运营、数据质量、业务目标脱节、模型偏差、数据安全、陷阱规避、实战策略摘要&#xff1a;大数据运营已成为企业数字化转型的核心引擎&#xff0c;但许多团队在实际落地中常陷入“数据越…

【毕业设计】基于Springboot的体育赛事视频管理系统(源码+文档+远程调试,全bao定制等)

博主介绍&#xff1a;✌️码农一枚 &#xff0c;专注于大学生项目实战开发、讲解和毕业&#x1f6a2;文撰写修改等。全栈领域优质创作者&#xff0c;博客之星、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java、小程序技术领域和毕业项目实战 ✌️技术范围&#xff1a;&am…

绿色AI:降低环境影响的计算策略

绿色AI:降低环境影响的计算策略 关键词:绿色AI、环境影响、计算策略、节能算法、可持续发展 摘要:本文聚焦于绿色AI领域,旨在探讨降低人工智能计算对环境影响的有效策略。随着AI技术的迅猛发展,其高能耗问题日益凸显,对环境造成了一定压力。文章首先介绍了绿色AI的背景,包…

基于改进下垂控制的微电网控制研究Simulink实现

✅作者简介&#xff1a;热爱科研的Matlab仿真开发者&#xff0c;擅长数据处理、建模仿真、程序设计、完整代码获取、论文复现及科研仿真。 &#x1f34e; 往期回顾关注个人主页&#xff1a;Matlab科研工作室 &#x1f447; 关注我领取海量matlab电子书和数学建模资料 &#x1…

基于非对称纳什谈判的多微网电能共享运行优化策略Matlab实现

✅作者简介&#xff1a;热爱科研的Matlab仿真开发者&#xff0c;擅长数据处理、建模仿真、程序设计、完整代码获取、论文复现及科研仿真。 &#x1f34e; 往期回顾关注个人主页&#xff1a;Matlab科研工作室 &#x1f447; 关注我领取海量matlab电子书和数学建模资料 &#x1…

配电网多目标pareto重构+智能算法Matlab代码

✅作者简介&#xff1a;热爱科研的Matlab仿真开发者&#xff0c;擅长数据处理、建模仿真、程序设计、完整代码获取、论文复现及科研仿真。 &#x1f34e; 往期回顾关注个人主页&#xff1a;Matlab科研工作室 &#x1f447; 关注我领取海量matlab电子书和数学建模资料 &#x1…

手把手教 - 单片机 MQTTS 协议通信测试

一、介绍 开发板:STM32F407 rt-thread版本:4.1.0 二、工程配置 2.1 以太网配置 2.2 rtc 时钟开启 2.3 软件包配置 MQTT 依赖包 - pahomqtt,版本:1.2.0 。启动 TLS 需设置 MQTT 线程栈大小 ≥ 6144 配置 mbedtls,版本:2.28.1 。必须增加帧长度。 无证书 SSL 连接(单…

特价股票与公司现金流管理效率的关系

特价股票与公司现金流管理效率的关系关键词&#xff1a;特价股票、公司现金流管理效率、财务分析、投资决策、市场估值摘要&#xff1a;本文旨在深入探讨特价股票与公司现金流管理效率之间的内在联系。通过对相关核心概念的阐述、算法原理的剖析、数学模型的构建以及实际案例的…

救命神器9个AI论文平台,本科生搞定毕业论文!

救命神器9个AI论文平台&#xff0c;本科生搞定毕业论文&#xff01; AI 工具助力论文写作&#xff0c;让毕业不走弯路 在当前高校教育中&#xff0c;毕业论文已成为本科生必须面对的一项重要任务。然而&#xff0c;从选题、资料收集到撰写、降重&#xff0c;每一个环节都可能让…

基于手肘法的kmeans聚类数的精确识别【K-means聚类】Matlab代码

✅作者简介&#xff1a;热爱科研的Matlab仿真开发者&#xff0c;擅长数据处理、建模仿真、程序设计、完整代码获取、论文复现及科研仿真。 &#x1f34e; 往期回顾关注个人主页&#xff1a;Matlab科研工作室 &#x1f447; 关注我领取海量matlab电子书和数学建模资料 &#x1…

基于 YOLOv8 的铁路作业人员安全防护 PPE 智能检测系统 [目标检测完整源码]

基于 YOLOv8 的铁路作业人员安全防护 PPE 智能检测系统 [目标检测完整源码] 一、应用背景与问题定义 在铁路施工、检修与日常巡线作业中&#xff0c;作业环境复杂、风险等级高。行业规范明确要求作业人员必须正确佩戴个人防护装备&#xff08;PPE&#xff09;&#xff0c;如安…

[Script] pwd

[Script] pwd 引言 正文 【示例 1】直接打印当前工作路径 【示例 2】获取返回值后打印当前工作路径 Author: JiJi \textrm{Author: JiJi} Author: JiJi Created Time: 2026.01.15 \textrm{Created Time: 2026.01.15} Created Time: 2026.01.15

初认Langchain,详细介绍Langchain是什么

前言当大语言模型&#xff08;LLM&#xff09;的浪潮席卷而来&#xff0c;无数开发者和创业者都怀揣着同一个梦想&#xff1a;构建一个能真正理解、推理并与现实世界交互的智能应用。然而&#xff0c;从一个简单的 curl 请求到一个健壮、可靠、可维护的产品&#xff0c;中间横亘…

[Script] feval

[Script] feval 推荐阅读 引言 正文 【示例 1】脚本文件名称中存在空格字符 【示例 2】脚本文件与当前脚本分别位于不同目录 【示例 3】运行脚本文件后当前工作路径不改变 Author: JiJi \textrm{Author: JiJi} Author: JiJi Created Time: 2026.01.15 \textrm{Created Time: 2…