【华为OD题库-029】恢复数字序列-java

题目

对于一个连续正整数组成的序列,可以将其拼接成一个字符串,再将字符串里的部分字符打乱顺序。如序列89101112, 拼接成的字符串19810112,打乱部分字符后得908112111。原来的正整数10就被拆成了0和1.现给定一个按如上规则得到的打乱字符的字符串,请将其还原成连续正整数序列,并输出序列中最小的数字,
输入描述
输入行,为打乱字符的字符串和正整数序列的长度,两者间用空格分隔,字符审长度不超过200,正整数不超过10000 保证输入可以还原成唯一序列。
输出描述
输出一个数字,为序列中最小的数字
示例1:
输入
19801211 5
输出
8
说明: 正常的数字序列为8 9 10 11 12这5个数字,最小数宇为8

思路

暴力法

  1. 最小值设为start=1,根据输入的序列长度n,得到start开始,长度为n的字符串tempstr
  2. 判断tempStr通过打乱顺序后是否能和输入的字符串相等。
  3. 如果相等,则返回start,否则继续遍历。
    关键在于第2步:如果字符串a打乱后能够得到字符串b,那么字符串a和b通过排序后得到的字符串一定是相等的。

滑动窗口

判断字符串a打乱后是否能够得到字符串b?字符的范围为[0-9],可以用一个int[10]的数组记录每个字符串出现的次数,如下:
在字符串a中各字符出现的次数得到int[] freqa;
在字符串b中各字符出现的次数得到int[] freqb;

如果freqa和freqb中每个字符出现的次数相等,那么就a打乱顺序后可以得到b
滑动窗口法的代码步骤如下:

  1. 用一个int[10]的数组target_freqs,记录输入字符串每个字符串出现的次数
  2. 初始化窗口:[1,2,3,4,n-1]。使用cur_freqs记录当前窗口每个字符串出现的次数
  3. 如果cur_freqs和target_freqs每个字符出现的次数均相等,那么返回此窗口最左侧的值
  4. 否则,开始右移窗口,加入一个n,删除一个1,并且维护cur_freqs的值

题解

滑动窗口

package hwod;import java.util.*;public class RecoveryNumQueue {private static int[] target_freqs = new int[10];private static int[] cur_freqs = new int[10];public static void main(String[] args) {Scanner sc = new Scanner(System.in);final String[] inputs = sc.nextLine().split(" ");String s = inputs[0];int n = Integer.parseInt(inputs[1]);System.out.println(recoveryNumQueue(s, n));}//滑动窗口private static int recoveryNumQueue(String s, int n) {//统计输入的字符串每个字符出现的次数for (int i = 0; i < s.length(); i++) {target_freqs[s.charAt(i) - '0'] += 1;}//初始化滑动窗口LinkedList<Integer> queue = new LinkedList<>();for (int i = 0; i < n; i++) {queue.addLast(i + 1);for (char c : String.valueOf(i + 1).toCharArray()) {cur_freqs[c - '0'] += 1;}}//移动窗口while (!check(cur_freqs, target_freqs)) {int addNum = queue.peekLast() + 1;for (char c : String.valueOf(addNum).toCharArray()) {cur_freqs[c - '0'] += 1;}queue.addLast(addNum);int removeNum = queue.peekFirst();for (char c : String.valueOf(removeNum).toCharArray()) {cur_freqs[c - '0'] -= 1;}queue.removeFirst();}return queue.peekFirst();}private static boolean check(int[] cur_freqs, int[] target_freqs) {for (int i = 0; i < 10; i++) {if (cur_freqs[i] != target_freqs[i]) return false;}return true;}
}

暴力破解

package hwod;import java.util.*;public class RecoveryNumQueue {private static int[] target_freqs = new int[10];private static int[] cur_freqs = new int[10];public static void main(String[] args) {Scanner sc = new Scanner(System.in);final String[] inputs = sc.nextLine().split(" ");String s = inputs[0];int n = Integer.parseInt(inputs[1]);System.out.println(recoveryNumQueue(s, n));}//暴力查找private static int recoveryNumQueue(String s, int n) {int ans = 0;while (true) {if (check(ans, n, s)) return ans;ans++;}}private static String sort(String string) {char[] chars = string.toCharArray();Arrays.sort(chars);return String.valueOf(chars);}private static boolean check(int start, int n, String s) {StringBuilder sb = new StringBuilder();for (int i = start; i < start + n; i++) {sb.append(i);}return sort(sb.toString()).equals(s);}
}

推荐

如果你对本系列的其他题目感兴趣,可以参考华为OD机试真题及题解(JAVA),查看当前专栏更新的所有题目。

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

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

相关文章

物联网AI MicroPython学习之语法 ADC数模模块

学物联网&#xff0c;来万物简单IoT物联网&#xff01;&#xff01; ADC 介绍 模块功能: ADC数模转换模块 ADC功能在ESP32引脚32-39上可用&#xff0c;使用默认配置时&#xff0c;ADC引脚上的输入电压必须介于0.0v和1.0v之间&#xff08;任何高于1.0v的值都将读为4095&#x…

【信息安全】浅谈三种XSS(跨站脚本攻击)的攻击流程与防御措施

XSS 跨站脚本攻击&#xff08;Cross-Site Scripting&#xff0c;简称XSS&#xff09;是一种常见的Web安全漏洞&#xff0c;攻击者通过在Web应用中注入恶意脚本&#xff0c;使得浏览器在解析页面时执行该脚本&#xff0c;从而实现攻击目的。 类型 存储型XSS&#xff1a;攻击者…

YoloV8改进策略:WaveletPool解决小目标的混叠问题,提高小目标的检测精度

文章目录 摘要论文:《抗混叠在微小目标检测中的重要性》1、简介2、相关研究2.1、微小物体检测2.2. 抗锯齿过滤器3、方法3.1. Wavelet Pooling3.2 一致顺序的Wavelet Pooling的WaveCNet3.3、Bottom-Heavy Backbone4、实验4.1、预训练数据集4.2、微小目标检测数据集4.3、抗混叠方…

从0开始学习JavaScript--JavaScript类型化数组进阶

前面的文章&#xff0c;已经介绍了JavaScript类型化数组的基本概念、常见类型和基本操作。在本文中&#xff0c;我们将深入探讨类型化数组的一些进阶特性&#xff0c;包括共享内存、大端小端字节序、以及类型化数组与普通数组之间的转换&#xff0c;通过更丰富的示例代码&#…

Keil MDK 安装

0 Preface/Foreword 1 下载和安装 官网&#xff1a;Keil Embedded Development Tools for Arm, Cortex-M, Cortex-R4, 8051, C166, and 251 processor families. Keil MDK 下载链接&#xff1a;Keil MDK 1.1 下载 根据需求下载对应的Keil MDK edition。 不同的editions包括 …

WaveletPool:抗混叠在微小目标检测中的重要性

文章目录 摘要1、简介2、相关研究2.1、微小物体检测2.2. 抗锯齿过滤器3、方法3.1. Wavelet Pooling3.2 一致顺序的Wavelet Pooling的WaveCNet3.3、Bottom-Heavy Backbone4、实验4.1、预训练数据集4.2、微小目标检测数据集4.3、抗混叠方法的选择及应用顺序4.4、小波的选择4.5、T…

Monoxide relay机制和连弩挖矿

这篇文章就两个点&#xff0c;relay机制 、 连弩挖矿 relay 最终原子性 Eventual Atomicity 一笔跨链交易&#xff0c;从取款shard中发出&#xff0c;到存款shard中. 当收款shard中将这笔夸片交易打包上链后&#xff0c;原子性才执行结束。 这样做的延迟是比较小的。 如何应…

Linux awk命令

一. 查询时间超过2000毫秒的请求 ✅log: 20231119-1.log 2023:11:19 09:07:10 SPLEND2000 请求开始 110 END 2023:11:19 09:07:11 SPLEND1000 请求开始 120 END 2023:11:19 09:07:12 SPLEND3000 请求开始 119 END 2023:11:19 09:07:13 SPLEND4000 请求开始 156 END 2023:11:1…

深度神经网络下的风格迁移模型

版权声明&#xff1a;本文为博主原创文章&#xff0c;转载请在显著位置标明本文出处以及作者网名&#xff0c;未经作者允许不得用于商业目的。 斯坦福大学李飞飞团队的风格迁移模型是一种基于深度学习的图像处理技术&#xff0c;可以将一张图像的风格转移到另一张图像上。该模型…

Go 命名规范:全面指南

关注公众号【爱发白日梦的后端】分享技术干货、读书笔记、开源项目、实战经验、高效开发工具等&#xff0c;您的关注将是我的更新动力&#xff01; 在软件开发领域中&#xff0c;命名规范在提升代码可读性、可维护性和一致性方面起着至关重要的作用。良好定义的命名规范确保代码…

python之循环

知识点&#xff1a;while 使用while循环一般需要定义一个标志位&#xff0c;用来开始和结束循环 flag True 注意&#xff1a;这里的True一定要大写&#xff0c;否则无法识别 当要循环结束的时候 flag False 例子 # 遍历所有的子列表&#xff0c;找出列表之和为最大的列表 d…

notepad++

目录 notepad标签自动补齐notepad安装插件&#xff1a;Emmet 和 Python Script第 1 步&#xff0c;安装emmet第 2 步&#xff0c;安装 Python Script第 3 步 更改快捷键 安装html代码格式化插件tidy21 安装2 使用2.1 效果 notepad快捷键 notepad标签自动补齐 1 2 3 打标签时…

MySQL数据库备份与恢复:物理备份和逻辑备份详解

MySQL数据库的备份与恢复是数据库管理中至关重要的一环&#xff0c;它确保了数据的安全性和可恢复性。在本文中&#xff0c;我们将深入讨论如何进行MySQL数据库的备份和恢复&#xff0c;并详解物理备份和逻辑备份的概念及区别。 1. 如何备份和恢复MySQL数据库&#xff1f; 1.…

编写函数求定积分的通用函数

归纳编程学习的感悟&#xff0c; 记录奋斗路上的点滴&#xff0c; 希望能帮到一样刻苦的你&#xff01; 如有不足欢迎指正&#xff01; 共同学习交流&#xff01; &#x1f30e;欢迎各位→点赞 &#x1f44d; 收藏⭐ 留言​&#x1f4dd; 不积跬步无以至千里&#xff0c;…

Hfish安全蜜罐部署

一、Hfish蜜罐介绍 HFish蜜罐官网 HFish是一款社区型免费蜜罐&#xff0c;侧重企业安全场景&#xff0c;从内网失陷检测、外网威胁感知、威胁情报生产三个场景出发&#xff0c;为用户提供可独立操作且实用的功能&#xff0c;通过安全、敏捷、可靠的中低交互蜜罐增加用户在失陷…

注册中心CAP架构剖析

Nacos 支持 AP 或 CP AP Nacos 通过临时节点实现 AP 架构&#xff0c;将服务列表放在内存中&#xff1b; CP Nacos 通过持久化节点实现 CP 架构&#xff0c;将服务列表放在文件中&#xff0c;并同步到内存&#xff0c;通过 Raft 协议算法实现&#xff1b; 通过配置 epheme…

智能座舱架构与芯片 - (3) 硬件篇 上

一、介绍 在了解智能座舱的基本架构之后&#xff0c;我们有必要针对智能座舱域的硬件平台&#xff0c;软件平台&#xff0c;SOC等进行逐一介绍。从它们的整体结构中去认识最新的智能座舱组成部件&#xff0c;以及主要功能等。 如上图&#xff0c;是中央计算-区域控制架构下的智…

Java Finalization‘s Memory-Retention Issues 及Reference类解析

引言 《Effective Java Programming Language Guide》 一书中强烈建议不要使用java的finalize()方法去做对象消亡前的清理。因为jvm调用finalize()方法的时机并不确定&#xff0c;容易导致Memory-Retention Issues。通俗点讲就是内存没办法及时回收。 详细的见oracle的官方说明…

数字电路的基础知识

一、数字电路概述 用数字信号完成对数字量进行逻辑运算和算术运算的电路称为数字电路。 由于它具有逻辑运算和逻辑处理功能&#xff0c;所以又称为数字逻辑电路。 现代的数字电路由半导体工艺制成的数字集成器件构造而成。 逻辑门是数字电路的基本单元电路&#xff0c;就如同在…

ES 查询语法-详解

文章目录 1.DSL查询文档1.1.DSL查询分类1.2.全文检索查询1.2.1.使用场景1.2.2.基本语法1.2.3.总结 1.3.精准查询1.3.1.term查询1.3.2.总结 1.DSL查询文档 elasticsearch的查询依然是基于JSON风格的DSL来实现的。 1.1.DSL查询分类 Elasticsearch提供了基于JSON的DSL&#xff…