LeetCode 670 最大交换数

周一,非常冷,大风呼呼的,上班路都走不动。

好消息,马上要过年了。大风吹,天气好。

过年过年,回家过年~

学生时代的迷茫是不应该存在的,最好的时光应该尽情享受,而不应该自己给加层阴霾。时间会带来答案。

今天再刷一题。

题目:给一个整数,最多可以交换这个数字的任意两位一次,获得可以返回的最大值。

理解:

(1)如果num <= 10, 直接返回num就可以了

(2) num可以分为两截,

第一截是非递增的,即num[i] >= num[i + 1]
第二截是有增有减,没有规律的。只要有递增,就存在第二截
第一截的长度可能为0,第二截的长度也可能为0.

如果只有第一截,即第二截的长度为0,那么num直接返回就行。
如果只有第二截,即第一截的长度为0,那么直接找出num中最大的一位,和第一位交换就行。

所以我们的解决思路分为两步

(1)找出是否存在第二截,只要存在nus[i] < num[i + 1],就存在第二截。
如果存在,找出第二截的最大值MAX。如果不存在,直接返回。

(2)从头开始(包括第一截),找到第一个小于MAX的值,与MAX交换即可。

public int maximumSwap(int num) {if(num <= 10) {return num;}// 找出是否存在第二截,只有存在递增情况,则有第二截。char[] nums = String.valueOf(num).toCharArray();int i = 0;while (i < nums.length - 1 && nums[i] >= nums[i + 1]) {++i;}// 非递增的,即nums只有第一截,直接返回if (i == nums.length - 1) {return num;}// 存在第二截,找到第二截的最大值MAX的下标jint j = i + 1;for (i = i + 1; i < nums.length; ++i) {if (nums[i] >= nums[j]) {j = i;}}// 找到第一个小于MAX的值num[i]的下标ii = 0;while (nums[i] >= nums[j]) {++i;}// 交换char temp = nums[i];nums[i] = nums[j];nums[j] = temp;// 返回return Integer.valueOf(String.valueOf(nums));}

结果
在这里插入图片描述

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

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

相关文章

西门子触摸屏维修6AV7880-0AA22-2DA2

西门子SIMATIC ITP1000平板PC机10.1 英寸采用 Intel Core i5 Skylake CPU&#xff0c;适合需要达16GB RAM的较高图形性能的工业移动计算应用。该 CPU 还提供了足够性能储备以满足将来的要求。安装的 Microsoft Windows 7 和 Microsoft Windows 10 操作系统以合理方式集成到现有…

68. redis计数与限流中incr+expire的坑以及解决办法(Lua+TTL)

文章目录 一、简介二、代码演进第一版代码&#xff08;存在bug隐患&#xff09;第二版代码&#xff08;几乎无隐患&#xff09;第三版代码(完美无瑕&#xff09; 一、简介 在日常工作中&#xff0c;经常会遇到对某种操作进行频次控制或者统计次数的需求&#xff0c;此时常用的…

RepLKNet 学习笔记

目录 原版测试代码: torch版本: RepLKNet 哔哩哔哩 原版测试代码: 1060显卡,224*224,平均时间10ms以内。 import timeimport torchfrom unireplknet import unireplknet_aif __name__ == __main__:net = unireplknet_a()net.cuda()net.eval()for i in range(20):

1411111111

第一张 用户管理表&#xff08;客户&#xff09; sys_user user_id 用户ID username 用户名 password 密码 phonenumber 电话 open_id 微信openID session_key 微信key user_type 管理员 维修员 客户 dept_id 部门ID 第五 维修人员表&#xff08;维修员&#xff09;sys_mainta…

深入了解Linux中常见的五种文件类型

了解文件类型对于正确理解和管理文件系统非常重要。希望本文能够帮助您更好地了解Linux中常见的文件类型及其在ls -l命令输出中的表示方式。​ 在Linux操作系统中&#xff0c;文件是操作系统中最基本的概念之一。在Linux中&#xff0c;每个文件都有一个特定的类型&#xff0c;这…

Elasticsearch分布式一致性原理剖析(一)-节点篇

前言 “Elasticsearch分布式一致性原理剖析”系列将会对Elasticsearch的分布式一致性原理进行详细的剖析&#xff0c;介绍其实现方式、原理以及其存在的问题等(基于6.2版本)。 ES目前是最流行的分布式搜索引擎系统&#xff0c;其使用Lucene作为单机存储引擎并提供强大的搜索查…

从0开始学习C++ 第二十课:模板与泛型编程

第二十课&#xff1a;模板与泛型编程 学习目标&#xff1a; 掌握模板的基本语法和概念。学会使用函数模板来创建可重用的函数。学习如何定义类模板以实现数据结构的泛型。理解模板在C中提供的灵活性和强大功能。 学习内容&#xff1a; 模板的概念&#xff1a; 模板是C中支持…

解决Git添加.gitignore文件后不生效的问题

1. 问题描述 如上图所示&#xff0c;在已存在.gitignore文件且已经提交过的Git管理的项目中&#xff0c;其中.class、.jar文件以及.idea目录内的内容全部都还是被Git管理了&#xff0c;可见.gitignore文件并没有生效。 2. 原因发现 .gitignore文件只能作用于 Untracked Files…

eNSP学习——配置通过FTP进行文件操作

原理概述&#xff1a; FTP&#xff08;File Transfer Protocol&#xff0c;文件传输协议&#xff09;是在TCP/IP网络和Internet上最早使用的协议之一&#xff0c;在TCP/IP协议族中属于应用层协议&#xff0c;是文件传输的Internet标准。主要功能是向用户提供本地和远程主机…

python--pyQt5 对话框使用(QInputDialog) PySide6

参考&#xff1a; https://www.cnblogs.com/XJT2018/p/10208710.html https://blog.csdn.net/panrenlong/article/details/79948261 含参数详解&#xff1a; https://blog.csdn.net/zhulove86/article/details/52515460 一、简介 QInputDialog类提供了一个简单的便捷对话框&a…

开源模型应用落地-业务整合篇(三)

一、前言 在之前的两篇文章中,我们学习了如何构建基本的即时消息(IM)功能。今天,我们将进一步将IM模块与AI服务进行连接,实现用户提问并由模型进行回答,最后将结果展示在用户界面上。 二、术语 2.1. Spring Boot 是一个用于快速构建基于Spring框架的Java应用程序的开源框…

python 编写dll给c++调用

Python可以通过ctypes库将Python函数封装为DLL文件&#xff0c;以便C程序调用。下面是一个简单的示例&#xff1a; 创建一个Python脚本&#xff0c;其中包含要封装的函数&#xff0c;例如&#xff1a; def add(x, y): return x y 将该脚本编译为DLL文件。可以使用pyinstalle…

深入浅出AI落地应用分析:AI音乐生成之「Suno.ai」

接下来会每周集中体验一些通用或者垂直的AI落地应用&#xff0c;主要以一些全球或者国外国内排行较前的产品为研究对象&#xff0c;「AI 产品榜&#xff1a; aicpb.com」以专题的方式在博客进行分享。 本节主要介绍和体验AI音乐生成应用产品Suno AI&#xff0c;Suno来自目前最…

HQL,SQL刷题简单查询,基础,尚硅谷

今天刷SQL简单查询&#xff0c;大家有兴趣可以刷一下 目录 相关表数据&#xff1a; 题目及思路解析&#xff1a; 总结归纳&#xff1a; 知识补充&#xff1a; 关于LIKE操作符/运算符 LIKE其他使用场景包括 LIKE模糊匹配情况 相关表数据&#xff1a; 1、student_info表 2、sc…

Unity中URP下获取主灯信息

文章目录 前言一、计算BulinnPhone的函数有两个重载1、 目前最新使用的是该方法&#xff08;这是我们之后主要分析的函数&#xff09;2、 被淘汰的老方法&#xff0c;需要传入一堆数据 二、GetMainLight1、Light结构体2、GetMainLight具有4个方法重载3、1号重载干了什么&#x…

主动轮廓——计算机视觉中的图像分割方法

​ 一、说明 简单来说&#xff0c;计算机视觉就是为计算机提供类似人类的视觉。作为人类&#xff0c;我们很容易识别任何物体。我们可以很容易地识别山丘、树木、土地、动物等&#xff0c;但计算机没有眼睛&#xff0c;也没有大脑&#xff0c;因此它很难识别任何图像。计算机只…

Linux下软件安装的命令【RPM,YUM】及常用服务安装【JDK,Tomcat,MySQL】

Linux下软件安装的命令 源码安装 以源代码安装软件&#xff0c;每次都需要配置操作系统、配置编译参数、实际编译&#xff0c;最后还要依据个人喜好的方式来安装软件。这个过程很麻烦很累人。 RPM软件包管理 RPM安装软件的默认路径: 注意&#xff1a; /etc 配置文件放置目录…

docker network网络

网络分类 bridge网络 bridge是docker默认网络模式&#xff0c;docker安装后会选择一个私有网段作为bridge的子网&#xff0c;在我们创建容器时默认会将容器网络加入到这个子网中。 原理&#xff1a;Docker Daemon&#xff08;后台进程&#xff09; 利用 veth pair 技术&#…

502. IPO(贪心算法+优先队列/堆)

整体思想&#xff1a;在满足可用资金的情况下&#xff0c;选择其中利润最大的业务&#xff0c;直到选到k个业务为止&#xff0c;注意k可能比n大。 每次选择完一个业务&#xff0c;可用资金都会变动&#xff0c;这是可选择的业务也会变化&#xff0c;因此每次将可选择的业务放在…

3dmax渲不出模型是什么原因---模大狮模型网

3DMax无法渲染模型可能有多种原因。以下是一些常见的问题和解决方法&#xff1a; 材质设置错误&#xff1a;检查模型的材质设置是否正确&#xff0c;包括纹理贴图的路径、UV映射是否正确等。确保材质的属性设置正确&#xff0c;如颜色、反射率、透明度等。 灯光设置问题&#…