备战蓝桥杯Day29 - 拼接最大数字问题

问题描述

有n个非负整数,将其按照字符串拼接的方式拼接为一个整数如何拼接可以使得得到的整数最大?

例: 32,94,128,1286,6,71可以拼接除的最大整数为 94716321286128。

问题思路

1.比较两个字符串的第一个数字,数值大的在前面,数值小的在后面

2.当两个字符串长度差不多且其中一个是另一个的字串时,从第一个数字开始比较两个字符串的方法就不太可行了。

3.更好的解决办法是:比较两个字符串结合在一起后的字符串的大小,比如:“128” + ”1286“ < "1286" + "128",通过比较字符串拼接后的数值大小,我们的算法也更容易实现。

代码实现

比较大小是调用python自带的包,也可以自己写冒泡排序来进行排序。

from functools import cmp_to_key
li = [32, 94, 128, 1286, 6, 71]def xy_cmp(x, y):  # 定义两个字符串拼接后数值比较函数if x+y < y+x:return 1  elif x+y > y+x:return -1else:return 0def num_join(li):  # 定义拼接函数li = list(map(str, li))  # 通过map函数将列表中的数字都转换成字符串格式li.sort(key=cmp_to_key(xy_cmp))return "".join(li)print(num_join(li))

家人们咱们就是说直接用冒泡排序排好序后连接字符串就可以了,上面这个函数不常用也不太好理解,直接冒泡排序实现超级简单!

li = [94, 65, 73, 128, 1286, 4]li = list(map(str, li))   # 将列表中的数字转为字符串类型的for i in range(len(li) - 1):  # 一整个就是冒泡排序的思想for j in range(len(li) - 1 - i):if li[j]+li[j+1] < li[j+1]+li[j]:  # 唯一不同是不是比较两个数字的大小# 而是比较两个数链接在一起后数值的大小li[j], li[j+1] = li[j+1], li[j]print("".join(li))  # 最后将列表中的字符都拼接起来

一步一步的大踏步向前吧!

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

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

相关文章

算法打卡day21|回溯法篇01|理论知识,Leetcode 77.组合

回溯法理论知识 回溯法也可以叫做回溯搜索法&#xff0c;它是一种搜索的方式。回溯是递归的副产品&#xff0c;只要有递归就会有回溯。所以回溯函数也就是递归函数&#xff0c;指的都是一个函数。 回溯法的效率 回溯法并不是什么高效的算法。因为回溯的本质是穷举&#xff0c;…

win提权第二弹服务提权

阅读须知&#xff1a; 探索者安全团队技术文章仅供参考,未经授权请勿利用文章中的技术资料对任何计算机系统进行入侵操作,由于传播、利用本公众号所提供的技术和信息而造成的任何直接或者间接的后果及损失&#xff0c;均由使用者 本人负责&#xff0c;作者不为此承担任何责任,如…

python多进程调用class类遇到的坑

测试环境 Python 3.9.17 系统&#xff1a;macOS Ventura 13.0.1 测试1 多进程采用test.run方式调用函数。 发现&#xff0c;调用的test.run 函数没运行 def multiprocessing_get_slow_log():pool Pool(3)sp Spider()conn sp.mysql_conncur conn.cursor()sql "&qu…

使用STM32 再实现电动车防盗

项目需求 点击遥控器 A 按键&#xff0c;系统进入警戒模式&#xff0c;一旦检测到震动&#xff08;小偷偷车&#xff09;&#xff0c;则喇叭发出声响报警&#xff0c; 吓退小偷。 点击遥控器 B 按键&#xff0c;系统退出警戒模式&#xff0c;再怎么摇晃系统都不会报警&…

Java并发编程-Java中的锁

1.简介 Java 中的锁是用于控制多线程对共享资源访问的一种机制&#xff0c;以防止数据的不一致性和脏读。Java 提供了多种锁机制&#xff0c;包括内置的同步机制&#xff08;synchronized&#xff09;和在 java.util.concurrent.locks 包中提供的显式锁&#xff08;如 Reentra…

3an推客是什么?有哪些优势

商家如何提升站外流量的?站外推广营销工具3an推客&#xff0c;帮助大家提升站外流量&#xff0c;为新品破零&#xff0c;打造爆款。一起来了解这个工具吧。 一、什么是3an推客 3an推客是一种站长联盟合作推广&#xff0c;其中CPS模式按照实际成交额计费的站外广告投放工具&a…

python编程之黑洞文件

之前我们学习了Python的爬虫及反爬技术&#xff0c;今天我们就来了一个恶作剧程序&#xff01; 这里主要涉及到Python的os,time&#xff0c;shutil这几个库 作用:它可以重复删除指定目录内的所有文件&#xff0c;千万不要小瞧这个功能&#xff0c;如果你指定的目录是像手机安…

3.6 条件判断语句cmp,je,ja,jb及adc、sbb指令

汇编语言 1. adc指令 adc是带进位加法指令&#xff0c;它利用了CF位上记录的进位值指令格式&#xff1a;adc 操作对象1&#xff0c;操作对象2功能&#xff1a;操作对象1 操作对象1 操作对象2 CF例如&#xff1a;adc ax,bx&#xff0c;实现的功能是&#xff1a;ax ax bx …

PyCharm中设置代码模版

前言 新创建一个.py文件后&#xff0c;我们总需要在开头写一些必要的代码&#xff0c;有什么方法能够一劳永逸&#xff0c;让这些代码自动生成呢&#xff1f; 有&#xff0c;它就是代码模版。 设置代码模版 这里先说说如何设置它。 步骤&#xff1a;首先打开PyCharm&#xff0…

隐私计算笔记(1)

一、可信流通体系 建立数据来源可确认、使用范围可界定、流通过程可追溯、安全风险可防范的数据可流通体系。 二、产生信任的基石 身份可确认利益可依赖能力有预期行为有后果 三、数据流通不可信风险 内循环&#xff1a;在内部循环中&#xff0c;数据持有方在其自身的运维…

MySQL介绍

一、MySQL数据库介绍 1、发展史 1996年 MySQL1.0 2008年1月16日 Sun公司收购了 MySQL 2009年4月20日 Oracle收购了Sun公司 MySQL是一种开放源代码的关系型数据库管理系统 使用最常用的数据库管理语言 SQL&#xff08;结构化查询语言&#xff09; MySQL是开放源代码的 因此所有…

c#使用onnxruntime调用yolo模型导出的onnx模型分割图片

1.今天写下c#中怎么使用yolo模型系列导出的onnx分割图片 2.yolo训练好后&#xff0c;把模型导出为onnx模式。 3.导出模型为onnx模式后&#xff0c;在window中要引用&#xff0c;可以使用 Microsoft.ML.OnnxRuntime库 4.window系统要求win10或者更高&#xff0c;vs用vs2022或更高…

【Kotlin】扩展属性、扩展函数

1 类的扩展 Kotlin 提供了扩展类或接口的操作&#xff0c;而无需通过类继承或使用装饰器等设计模式&#xff0c;来为某个类添加一些额外的属性或函数&#xff0c;我们只需要通过一个被称为扩展的特殊声明来完成。通过这种机制&#xff0c;我们可以将那些第三方类不具备的功能强…

C语言例3-35:长度运算的例子

长度运算符的表现形式&#xff1a; sizeof(数据类型符&#xff09; 或 sizeof(变量&#xff09; 长度运算符的优先级&#xff1a; 与单目算术运算符、单目逻辑运算符、自增和自减运算符的优先级相同。上述优先级相同的运算符的结合性都是从右至左。 长度运算的例子 代码如…

二手交易平台|基于JSP技术+ Mysql+Java+ B/S结构的二手交易平台设计与实现(可运行源码+数据库+设计文档)

推荐阅读100套最新项目 最新ssmjava项目文档视频演示可运行源码分享 最新jspjava项目文档视频演示可运行源码分享 最新Spring Boot项目文档视频演示可运行源码分享 2024年56套包含java&#xff0c;ssm&#xff0c;springboot的平台设计与实现项目系统开发资源&#xff08;可…

关于在ArkTS中添加动画没有效果这件事

先来看看错的 Entry Component struct an {State a : number 0;State ang : number 0;build() {Row(){Text(^_^).fontSize(90).position({x : 0,y : this.a}).rotate({angle : this.ang,centerX : 50%,centerY : 50%}).onClick(() > {this.a 100;}).animation({duration…

okcc呼叫中心线路不通可以跳下一个线路吗?

在 OKCC&#xff08;呼叫中心系统&#xff09;中&#xff0c;通常可以通过设置线路故障跳过功能来实现在当前线路不通的情况下自动跳转到下一个可用线路进行呼叫。这项功能可以提高呼叫成功率和系统的稳定性。具体操作步骤可能会略有不同&#xff0c;技术问题欢迎微博主kelaile…

亚马逊等跨境电商平台自养号测评的五个核心因素

一、安全稳定的环境系统 尽管市场上存在大量现成的系统和软件包&#xff0c;卖个软件或设备给你&#xff0c;这种基本上都没有解决风控的能力&#xff0c;因此&#xff0c;小编推荐大家还是自己掌握相关技术&#xff0c;避免过度依赖于外部资源&#xff0c;目前&#xff0c;也…

通过电机相电流计算电机反电动势

要通过电机的相电流来计算电机的反电动势&#xff08;back electromotive force, BEMF&#xff09;&#xff0c;可以使用以下方法&#xff1a; 给定相电流和电机参数&#xff1a;首先&#xff0c;你需要测量或获取电机的相电流值&#xff0c;这通常是通过电流传感器实现的。同时…

.net core 接入nacos

安装nacos 安装nacos .net core 接入nacos 引用包 nacos-sdk-csharpnacos-sdk-csharp.Extensions.Configuration Program 代码 public static IHostBuilder CreateHostBuilder(String[] args) >Host.CreateDefaultBuilder(args).ConfigureAppConfiguration((hostingCon…