Python算法例19 创建最大数

1. 问题描述

给定两个长度分别是m和n的数组,数组的每个元素都是数字0~9,从这两个数组当中选出k个数字来创建一个最大数,其中k满足k<=m+n,选出来的数字在创建最大数里的位置必须与在原数组内的相对位置一致。返回k个元素的整数数组,尽可能优化算法的时间复杂度和空间复杂度。

2. 问题示例

给出nums1=[3,4,6,5],nums2=[9,1,2,5,8,3],k=5,返回[9,8,6,5,3];给出nums1=[6,7],nums2=[6,0,4],k=5,返回[6,7,6,0,4];给出nums1=[3,9],nums2=[8,9],k=3,返回[9,8,9]。

3. 代码实现

使用贪心算法来解决。具体来说,我们可以固定从nums1中选取多少个数字,然后从nums2中选取剩余的数字,使得它们合起来构成一个长度为k的最大数。

为了实现这个算法,我们需要确定以下步骤:

  1. 实现一个函数,将一个数组中的元素重排,使得它们构成的数字最大;
  2. 对于一个给定的数组nums和整数k,我们需要找到由nums中的数字组成的长度为k的最大数;
  3. 给定两个数组nums1和nums2以及整数k,我们需要找到由nums1和nums2中的数字组成的长度为k的最大数。
def maxNumber(nums1, nums2, k):# 重排数组中的元素,使得它们构成的数字最大def merge(A, B):return [max(A, B).pop(0) for _ in A+B]# 找到由nums中的数字组成的长度为k的最大数def prepare(nums, k):drop = len(nums) - kout = []for num in nums:while drop and out and out[-1] < num:out.pop()drop -= 1out.append(num)return out[:k]# 找到由nums1和nums2中的数字组成的长度为k的最大数def lexicographically_greater(a, i, b, j):while i < len(a) and j < len(b) and a[i] == b[j]:i += 1j += 1return j == len(b) or (i < len(a) and a[i] > b[j])# 尝试从nums1中选取i个数字,从nums2中选取k-i个数字res = []for i in range(max(0, k-len(nums2)), min(k, len(nums1))+1):candidate = merge(prepare(nums1, i), prepare(nums2, k-i))res = max(candidate, res) if res != [] else candidatereturn res
nums1 = [3, 4, 6, 5]
nums2 = [9, 1, 2, 5, 8, 3]
k = 5
result = maxNumber(nums1, nums2, k)
print(result)  # 输出 [9, 8, 6, 5, 3]

其中,函数merge()用于将两个数组合并成一个最大数,函数prepare()用于找到由一个数组中的数字组成的长度为k的最大数,函数lexicographically_greater()用于比较两个数组的字典序大小。具体来说,这个函数的作用是,给定两个数组a和b以及它们的起始下标i和j,如果在i和j之后,a比b字典序更大,则返回True,否则返回False。

在主函数maxNumber()中,我们枚举从nums1中选取的数字的个数i,然后从nums2中选取剩余的数字k-i,将它们合并成一个最大数candidate。最后,我们将所有生成的最大数中的最大者返回即可。这个算法的时间复杂度为O((m+n)^3),空间复杂度为O(m+n)。

采用动态规划的方法。具体来说,我们可以使用两个动态规划数组来保存最大数的信息,以减少重复计算。

def maxNumber(nums1, nums2, k):def get_max_subsequence(nums, k):stack = []pop_count = len(nums) - kfor num in nums:while pop_count and stack and stack[-1] < num:stack.pop()pop_count -= 1stack.append(num)return stack[:k]def merge(nums1, nums2):merged = []i, j = 0, 0while i < len(nums1) and j < len(nums2):if nums1[i:] > nums2[j:]:merged.append(nums1[i])i += 1else:merged.append(nums2[j])j += 1merged.extend(nums1[i:])merged.extend(nums2[j:])return mergedresult = []for i in range(max(0, k-len(nums2)), min(k, len(nums1))+1):subsequence1 = get_max_subsequence(nums1, i)subsequence2 = get_max_subsequence(nums2, k-i)merged = merge(subsequence1, subsequence2)result = max(result, merged)return result
nums1 = [6,7]
nums2 = [6,0,4]
k = 5
result = maxNumber(nums1, nums2, k)
print(result)

在这个实现中,我们定义了两个辅助函数:get_max_subsequence()和merge()。函数get_max_subsequence()用于从一个数组中获取长度为k的最大子序列,这个函数的实现与之前贪心算法中的prepare()函数相同。函数merge()用于合并两个子序列,这个函数的实现与之前贪心算法中的merge()函数相同。

在主函数maxNumber()中,我们使用动态规划来生成最大数。我们首先枚举从nums1中选取的数字的个数i,然后使用get_max_subsequence()函数分别从nums1和nums2中获取长度为i和k-i的最大子序列。接下来,我们使用merge()函数将这两个子序列合并成一个最大数,并将其与之前的结果比较,保留更大的那个。最后,返回最终的最大数。这个算法的时间复杂度为O((m+n)^2),空间复杂度为O(m+n)。

使用单调栈的思想来减少重复计算。具体来说,我们可以使用两个单调递减栈,分别从nums1和nums2中构建。栈的长度为k,每次入栈时,判断当前元素与栈顶元素的大小关系,如果当前元素更大,则将栈顶元素出栈,直到满足栈的长度要求或者栈为空。然后将当前元素入栈。

def maxNumber(nums1, nums2, k):def build_max_stack(nums, k):stack = []drop_count = len(nums) - kfor num in nums:while drop_count > 0 and stack and stack[-1] < num:stack.pop()drop_count -= 1stack.append(num)return stack[:k]def merge(nums1, nums2):merged = []i, j = 0, 0while i < len(nums1) and j < len(nums2):if nums1[i:] > nums2[j:]:merged.append(nums1[i])i += 1else:merged.append(nums2[j])j += 1merged.extend(nums1[i:])merged.extend(nums2[j:])return mergedresult = []for i in range(max(0, k - len(nums2)), min(k, len(nums1)) + 1):subsequence1 = build_max_stack(nums1, i)subsequence2 = build_max_stack(nums2, k - i)merged = merge(subsequence1, subsequence2)result = max(result, merged)return result
nums1 = [3,9]
nums2 = [8,9]
k = 3
result = maxNumber(nums1, nums2, k)
print(result)

在这个实现中,我们使用了两个辅助函数:build_max_stack()和merge()。函数build_max_stack()用于构建单调递减栈,获取长度为k的最大子序列。函数merge()用于合并两个子序列。

在主函数maxNumber()中,我们通过枚举从nums1中选取的数字的个数i,分别构建nums1和nums2的单调递减栈,并通过merge()函数将这两个子序列合并成一个最大数。最后,返回最终的最大数。这个算法的时间复杂度为O(m+n+k(m+n)),其中m和n分别是nums1和nums2的长度。

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

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

相关文章

宝塔Linux面板计划任务:文件夹改名方式天天切割日志脚本

新手第一次操作&#xff0c;目测成功且完美&#xff0c;供大家参考 current_time$(date %Y%m%d%H%M%S) old_folder_name"/www/wwwlogs" new_folder_name"/www/wwwlogs_${current_time}" mv "$old_folder_name" "$new_folder_name" m…

layui 树组件tree 通过API获取数据

一、简单 var treedata[];tree.render({elem: #addLeftType,id: demoId,data: treedata,showCheckbox: true,oncheck: function(obj){console.log(obj.data); // 得到当前点击的节点数据console.log(obj.checked); // 节点是否被选中console.log(obj.elem); // 得到当前节点元素…

什么是数据仪表板?数据可视化仪表盘怎么制作?

在数据经济时代&#xff0c;分析数据是每个企业做出最佳决策的关键。但是&#xff0c;手动分析和解释大量数据是不可行的。数据可视化对于分析数据中存在的各种有价值信息至关重要&#xff0c;包括可见趋势和隐藏趋势等。仪表盘显示可视化趋势和信息&#xff0c;例如 KPI、趋势…

npm安装依赖报错ERESOLVE unable to resolve dependency tree(我是在taro项目中)(node、npm 版本问题)

换了电脑之后新电脑安装包出错 &#x1f447;&#x1f447;&#x1f447; npm install 安装包报错 ERESOLVE unable to resolve dependency tree 百度后尝试使用 npm install --force 还是报错 参考 有人说是 node 版本和 npm 版本的问题 参考 新电脑 node版本&#xff1a;16.1…

HackTheBox - Medium - Windows - Aero

Aero 这个机器利用了今年比较新的cve&#xff0c;关于windows11的漏洞&#xff0c;类似于lnk、scf&#xff0c;但这个危害更高&#xff0c;通过易受攻击的windows11 利用theme、msstyles来实现RCE. Aero 是一台中等难度的 Windows 机器&#xff0c;最近有两个 CVE&#xff1a;…

Apache Tomcat httpoxy 安全漏洞 CVE-2016-5388 已亲自复现

Apache Tomcat httpoxy 安全漏洞 CVE-2016-5388 已亲自复现 漏洞名称漏洞描述影响版本 漏洞复现环境搭建漏洞利用修复建议 总结 漏洞名称 漏洞描述 在Apache Tomcat中发现了一个被归类为关键的漏洞&#xff0c;该漏洞在8.5.4(Application Server Soft ware)以下。受影响的是组…

语音识别与人机交互:发展历程、挑战与未来前景

导言 语音识别技术作为人机交互领域的重要组成部分&#xff0c;近年来取得了巨大的发展。本文将深入研究语音识别与人机交互的发展历程、遇到的问题、解决过程、未来的可用范围&#xff0c;以及在各国的应用和未来的研究趋势。我们将探讨在这个领域&#xff0c;哪一方能取得竞争…

comfyUI + animateDiff video2video AI视频生成工作流介绍及实例

原文&#xff1a;comfyUI animateDiff video2video AI视频生成工作流介绍及实例 - 知乎 目录 收起 前言 准备工作环境 comfyUI相关及介绍 comfyUI安装 生成第一个视频 进一步生成更多视频 注意事项 保存为不同的格式 视频宽高设置 种子值设置 提示词与负向提示词…

如何将图片转为PDF

问题描述&#xff1a;如何将图片转为PDF&#xff0c;有时需要将纸质文档扫描成PDF&#xff0c;然后上传到网上。 解决办法&#xff1a;平时使用的方法是将图片插入到word文件中&#xff0c;然后将图片设置为浮于文字下方&#xff0c;然后调整图片的大小&#xff0c;铺满整个wo…

如何进一步优化Ubuntu服务器的性能

导读&#xff1a; 要进一步优化Ubuntu服务器的性能&#xff0c;您可以考虑以下几个方面&#xff1a;优化软件包管理&#xff1a; Ubuntu使用APT&#xff08;Advanced Package Tool&#xff09;作为其软件包管理工具。为了提高性能&#xff0c;您可以采取以下措施 要进一步优化U…

C# Tcplistener,Tcp服务端简易封装

文章目录 前言相关文章前言设计代码简单使用运行结果 前言 我最近有个需求要写Tcp服务端&#xff0c;我发现Tcp服务端的回调函数比较麻烦&#xff0c;简化Tcp的服务&#xff0c;我打算自己封装一个简单的Tcp服务端。 相关文章 C# TCP应用编程三 异步TCP应用编程 C# Tcpclient…

【ArcGIS微课1000例】0081:ArcGIS指北针乱码解决方案

问题描述&#xff1a; ArcGIS软件在作图模式下插入指北针&#xff0c;出现指北针乱码&#xff0c;如下图所示&#xff1a; 问题解决 下载并安装字体&#xff08;配套实验数据包0081.rar中获取&#xff09;即可解决该问题。 正常的指北针选择器&#xff1a; 专栏介绍&#xff…

Python Pandas Excel/csv文件的保存与读取(第14讲)

Python Pandas Excel/csv文件的读取于保存(第14讲)         🍹博主 侯小啾 感谢您的支持与信赖。☀️ 🌹꧔ꦿ🌹꧔ꦿ🌹꧔ꦿ🌹꧔ꦿ🌹꧔ꦿ🌹꧔ꦿ🌹꧔ꦿ🌹꧔ꦿ🌹꧔ꦿ🌹꧔ꦿ🌹꧔ꦿ🌹꧔ꦿ🌹꧔ꦿ🌹꧔ꦿ🌹꧔ꦿ🌹꧔ꦿ🌹꧔ꦿ🌹꧔ꦿ🌹꧔…

Redis BitMap(位图)

这里是小咸鱼的技术窝&#xff08;CSDN板块&#xff09;&#xff0c;我又开卷了 之前经手的项目运行了10多年&#xff0c;基于重构&#xff0c;里面有要实现一些诸如签到的需求&#xff0c;以及日历图的展示&#xff0c;可以用将签到信息存到传统的关系型数据库&#xff08;MyS…

2017年第六届数学建模国际赛小美赛A题飓风与全球变暖解题全过程文档及程序

2017年第六届数学建模国际赛小美赛 A题 飓风与全球变暖 原题再现&#xff1a; 飓风&#xff08;也包括在西北太平洋被称为“台风”的风暴以及在印度洋和西南太平洋被称为“严重热带气旋”&#xff09;具有极大的破坏性&#xff0c;往往造成数百人甚至数千人死亡。   许多气…

【Transformer框架代码实现】

Transformer Transformer框架注意力机制框架导入必要的库Input Embedding / Out EmbeddingPositional EmbeddingTransformer EmbeddingScaleDotProductAttention(self-attention)MultiHeadAttention 多头注意力机制EncoderLayer 编码层Encoder多层编码块&#xff0f;前馈网络层…

CentOS安装Python解释,CentOS设置python虚拟环境,linux设置python虚拟环境

一、安装python解释器 1、创建解释器安装的目录&#xff1a;/usr/local/python39 cd /usr/local mkdir python39 2、下载依赖 yum -y install zlib-devel bzip2-devel openssl-devel ncurses-devel sqlite-devel readline-devel tk-devel gcc make libffi-devel xz-devel …

【蓝桥杯】专题练习

前缀和 3956. 截断数组 - AcWing题库 一看到题目很容易想到的思路是对数组求前缀和&#xff0c;然后枚举两个分段点就好&#xff0c;时间复杂度是On^2&#xff0c;n是1e5会t&#xff0c;需要优化。 朴素的代码&#xff0c;会超时&#xff1a; #include <bits/stdc.h> u…

【小白专用】php pdo sqlsrv 类,php连接sqlserver

1.找到自己版本&#xff0c;我的程序是64位的。 注意&#xff1a;ts与nts的区别&#xff0c;查看phpinfo信息&#xff0c;如下 <?phpecho phpinfo();?> 2.运行后&#xff0c;可以查看到如下数据&#xff1a; ① PHP 的版本是8.2.13&#xff1b; ② 属于线程安全版 ts…

Axure中继器的使用

目录 一. 中继器 概述 作用 运用场景 二. 中继器的使用 三. 三列表格增删改查案例展示 一. 中继器 概述 在Axure软件中&#xff0c;中继器&#xff08;Repeater&#xff09;是一种特殊的控件&#xff0c;它的作用是允许用户创建重复的数据项&#xff0c;并以列表或表格…