python使用贪心算法求最大整数问题

news2025/2/26 2:03:09

对于使用贪心算法的一个比较经典的问题,主要是为了解决最大整数的拼接问题,如果给定一个列表,这个列表中所包括的是一些非负整数,如果对这些整数进行组合,怎样才能组合出一个最大的整数,这里要注意一个问题,有可能整数过大会导致出现溢出的现象,所以返回的数据可以是一个字符类型,这样就可以防止溢出。

添加图片注释,不超过 140 字(可选)

对如上的一个给定列表中的数据进行排列,这里如果考虑将本身值较大的放在前面的话,就不会得到拼接后较大的值,因为12112并没有12121数值大,所以正确的解决问题的思路是通过拼接两个字符,对比确定那个位于前面的时候才能够得到较大的整数。

添加图片注释,不超过 140 字(可选)

再例如,如果给定的另外一个列表如上图,就在决定两个元素如何拼接时,不能简单通过两个元素大小进行判断,将两个元素不同拼接方式所组成的数字的大小进行拼接后对比,这里使用的是双层循环,对数组中的遍历,每两个元素进行组合,每次循环分别确定最终拼接的第1位一直到最后一位,然后将元素按照顺序拼接起来返回即可。

添加图片注释,不超过 140 字(可选)

双层循环遍历数组中两两元素的组合方式,每次循环确定一个位置的元素,经过排序这个列表中元素的顺序得到最终结果,这里要注意一个特殊情况,当列表中元素均为0时,最终返回的结果是多个0,这里要将其转换一个元素0。使用python实现的代码如下:

def largestNumber(nums):
    nums=[str(i) for i in nums]
    for i in range(len(nums)-1):
        for j in range(i+1,len(nums)):
            if int(nums[i]+nums[j])<int(nums[j]+nums[i]):
                temp=nums[i]
                nums[i]=nums[j]
                nums[j]=temp
    if int(''.join(nums))==0:
        return str(0)
    else:
        return ''.join(nums)

对如上的一个代码还可以进行优化:

from functools import cmp_to_key 
def largestNumber(nums):
    nums=[str(i) for i in nums]
    nums.sort(key=cmp_to_key(lambda x,y:int(y+x)-int(x+y)))
    if int(''.join(nums))==0:
        return '0'
    else: 
        return ''.join(nums)

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

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

相关文章

自动派单系统哪家好?实现自动派单对于管理有什么帮助?

随着科技的发展&#xff0c;自动化管理已成为各行各业追求效率与精准的关键。在维修服务领域&#xff0c;自动派单系统的出现为管理员和用户带来了前所未有的便捷。通过自动匹配维修人员、实时通知用户进度等功能&#xff0c;自动派单系统不仅提高了派单的准确性和效率&#xf…

django后台进行加密手机号字段,加密存储,解密显示

需求: 1 &#xff1a;员工在填写用户的手机号时&#xff0c;直接填写&#xff0c;在django后台中输入 2&#xff1a;当员工在后台确认要存储到数据库时&#xff0c;后台将会把手机号进行加密存储&#xff0c;当数据库被黑之后&#xff0c;手机号字段为加密字符 3&#xff1a;员…

Python基础第一篇(Python概念介绍)

文章目录 一、前言&#xff1a;二、第一个Python程序三&#xff0c;理解Python的解释器四&#xff0c;Python解释器的使用五&#xff0c;Python开发环境 一、前言&#xff1a; 欢迎来到我们的Python学习专栏。在这里&#xff0c;我们将一起探索Python这门强大、灵活、易于学习…

微信小程序+前后端开发学习材料2-(视图+基本内容+表单组件)

学习来源 视图 1.swiper 滑块视图容器。其中只可放置swiper-item组件&#xff0c;否则会导致未定义的行为。 显示面板指示点indicator-dots 基础内容 1.icon 图标组件 实例演示 2.progress 进度条。组件属性的长度单位默认为px&#xff0c;咱用rpx。 实例演示 这…

SVO编译

文章目录 软件版本错误编译运行轨迹路径保存运行TUM数据集 附录针对svo slam的/svo/pose_imu转为tum格式代码 软件版本 ubuntu 20 rosnoeticSVO SLAM虚拟机 windows 11 错误 常见的git clone问题可以使用DevSidecar解决&#xff0c;在 加速服务-基本设置-绑定IP 设置为0.0.0…

Cinder对接NFS文件系统实验详解

2、对接NFS&#xff08;Network File System&#xff1a;网络文件系统&#xff09;实验 实验前的准备&#xff1a; 完整克隆一台虚拟机作为Cinder的后端存储&#xff08;IP为192.168.100.40&#xff09; Cinder节点作为服务端&#xff0c;把Controller作为客户端 Controlle…

git仓库使用说明

Git软件使用 1.先下载git相关软件 下载地址&#xff1a; Git - Downloading Package (git-scm.com) 下载其中一个安装 2.打开gitee网站&#xff0c;注册账号 3.打开个人中心&#xff0c;选择ssh公钥&#xff0c;查看如何生成公钥 4.生成公钥后&#xff0c;添加相应的公钥 …

Docker 安装 PHP

Docker 安装 PHP 安装 PHP 镜像 方法一、docker pull php 查找 Docker Hub 上的 php 镜像: 可以通过 Sort by 查看其他版本的 php&#xff0c;默认是最新版本 php:latest。 此外&#xff0c;我们还可以用 docker search php 命令来查看可用版本&#xff1a; runoobrunoob:…

AI 视频 | HiDream.ai 支持长视频,突破 4 秒限制!

2024 年&#xff0c;AI 视频领域大有可为。那么想卷 AI 视频领域&#xff0c;首先得掌握几个 AI 视频的工具。 之前的文章已经分享了一些常用的 AI 视频工具&#xff0c;比如 Pika、Runway Gen-2、Moonvalley、NeverEnds、DomoAI 以及 Stable Video Diffusion。 这些「往期 A…

关于Access中列的冻结的知识,看这篇就够了

在Microsoft Access中&#xff0c;有一个名为“冻结”的功能&#xff0c;使用户可以在滚动到另一个区域时保持数据表的某个区域可见。 可以使用冻结功能冻结数据表中的表、查询、窗体、视图或存储过程中的一个或多个字段。你冻结的字段将移动到数据表的左侧位置。 如何在Micr…

Unity关于纹理图片格式带来的内存问题和对预制体批量格式和大小减半处理

我们经常会遇到内存问题&#xff0c;这次就是遇到很多图片的默认格式被改成了RGB32&#xff0c;导致Android打包后运行内存明显增加。 发生了什么 打包Android后&#xff0c;发现经常崩溃&#xff0c;明显内存可能除了问题&#xff0c;看了内存后发现了问题。 见下图&#xf…

学习python仅此一篇就够了(使用python操作数据库)

python操作mysql SQL语言的分类 数据定义&#xff1a;DDL 数据操作&#xff1a;DML 数据控制&#xff1a;DCL 数据查询&#xff1a;DQL SQL支持注释&#xff1a;单行注释&#xff1a;--&#xff1b;单行注释#&#xff1b;多行注释&#xff1a;/* */ #查看数据库 show da…

Filter过滤器、使用场景、使用办法、创建和配置等

这里写目录标题 过滤器应用场景自动登录统一设置编码格式访问权限控制敏感字符过滤 Filter使用Filter的创建和配置 过滤器 过滤器实际上就是对 web资源进行拦截&#xff0c;做一些处理后再交给下一个过滤器或 servlet处理通常都是用来拦截request进行处理的&#xff0c;也可以…

再见了RDM,Redis官方GUI才是最好的!

1 简介 直观高效的 Redis GUI 管理工具&#xff0c;它可以对 Redis 的内存、连接数、命中率以及正常运行时间进行监控&#xff0c;并且可以在界面上使用 CLI 和连接的 Redis 进行交互&#xff08;RedisInsight 内置对 Redis 模块支持&#xff09;&#xff0c;官方下载地址。 使…

大师学SwiftUI第6章 - 声明式用户界面 Part 4

步进器视图 ​​Stepper​​视图创建一个带递增和递减按钮的控件。该结构体提供了多个初始化方法&#xff0c;包含不同的配置参数组合。以下是最常用的一部分。 Stepper(String, value: Binding, in: Range, step: Float, onEditingChanged: Closure)&#xff1a;此初始化方法…

基于Prism框架的WPF前端框架开发《知产代理数字化解决方案》

最近新开发了一套WPF前端界面框架&#xff0c;叫《知产代理数字化解决方案》&#xff0c;采用了时下流行的Prism框架作为整个系统的基础架构&#xff0c;演示了Prism中的IRegionManager区域管理器、IDialogAware对话框、IDialogService对话框服务、IContainerExtension容器等用…

财务思维一张图

系统研读了《肖星的财务思维课》和得到《贾宁财务思维课》&#xff0c;尝试用一张最简单的图总结财务思维所学到精髓吧。 《肖星的财务思维课》 得到《贾宁财务思维课》 附&#xff1a; 【清华大学】最好的财务课《商业的财务逻辑》&#xff08;全7课&#xff09;肖星教授 【…

Multimodal Multitask Learning with a Unified Transformer

SNLI-VE dataset&#xff0c;natural language understanding tasks&#xff1a;MNLI&#xff0c;QNLI&#xff0c;QQP&#xff0c;SST-2 截止到发文时间的issue数&#xff0c;多吓人呐&#xff0c;不建议复现

猫头虎博主第9期赠书活动:《YOLO目标检测》计算机AI视觉实战YOLO人工智能目标检测与跟踪图像处理深度学习图像检测书籍

博主猫头虎的技术世界 &#x1f31f; 欢迎来到猫头虎的博客 — 探索技术的无限可能&#xff01; 专栏链接&#xff1a; &#x1f517; 精选专栏&#xff1a; 《面试题大全》 — 面试准备的宝典&#xff01;《IDEA开发秘籍》 — 提升你的IDEA技能&#xff01;《100天精通Golang》…

分析Unity崩溃日志(Android)

Unity版本&#xff1a; 这里Unity版本是Unity 2019.4.30f1 崩溃信息&#xff1a; 错误信息如下&#xff1a; Exception Appversion: versionName 1.0.1 versionCode 1 Process: sg.atla.f.c PID: 22716 UID: 10749 Flags: 0x3088be44 Package: sg.atla.f.c v1 (1.0.1) Fo…