题目:

给定一个非负整数,你至多可以交换一次数字中的任意两位。返回你能得到的最大值。

示例 1 :

输入: 2736
输出: 7236
解释: 交换数字2和数字7。
示例 2 :

输入: 9973
输出: 9973
解释: 不需要交换。

注意: 给定数字的范围是 [0, 108]

来源:力扣(LeetCode)
链接:https://leetcode.cn/problems/maximum-swap
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

解题思路:

1.首先将数字转换成字符数组便于遍历每一个数字;

2.数字从后往前遍历,用一个数组记录每一个数字对应的最大索引;

3.再从头遍历原数组,当原数组的值与当前位置对应的最大索引值的原数组的值不相等时(有点绕口,看下面的例子就清楚了),就进行交换,交换完成就退出循环,将字符数组转换成整数输出即为结果。

例1:

数字98367

1.先确定最大索引值数组maxArr=[0,1,4,4,4]

从后往前遍历:
遍历7:最大值是7,7的索引值为4
遍历6:最大值是7,7的索引值为4
遍历3:最大值是7,7的索引值为4
遍历8:最大值是8,8的索引值为1
遍历9:最大值是9,9的索引值为0

2.进行原数组遍历,当原数组与当前最大值索引对应的值不相等时进行交换,结果为98763

nums[0] = 9, nums[maxArr[0]] = 9,相等不交换跳过;
nums[1] = 8, nums[maxArr[1]] = 8,相等不交换跳过;
nums[2] = 3, nums[maxArr[2]] = 7,不相等,进行交换为98763;

例2:

数字97257

1.先确定最大索引值数组maxArr=[0,4,4,4,4]

从后往前遍历:
遍历7:最大值是7,7的索引值为4
遍历5:最大值是7,7的索引值为4
遍历2:最大值是7,7的索引值为4
遍历7:最大值是7,7的索引值为4
遍历9:最大值是9,9的索引值为0

2.进行原数组遍历,当原数组与当前最大值索引对应的值不相等时进行交换,结果为98763

nums[0] = 9, nums[maxArr[0]] = 9,相等不交换跳过;
nums[1] = 7, nums[maxArr[1]] = 7,相等不交换跳过;
nums[2] = 2, nums[maxArr[2]] = 7,不相等,进行交换为97752;

代码:

 1 class Solution {
2 public int maximumSwap(int num) {
3 //将数字转换成字符数组
4 char[] nums = Integer.toString(num).toCharArray();
5 int[] maxArr = new int[nums.length];
6 int maxIdx = nums.length - 1;
7 //确定最大索引值数组
8 for(int i = nums.length - 1; i >= 0; i--){
9 if(nums[i] > nums[maxIdx]){
10 maxIdx = i;
11 }
12 maxArr[i] = maxIdx;
13 }
14
15 for(int i = 0; i < nums.length; i++){
16 if(nums[maxArr[i]] != nums[i]){
17 char temp = nums[i];
18 nums[i] = nums[maxArr[i]];
19 nums[maxArr[i]] = temp;
20 break;
21 }
22 }
23 return Integer.parseInt(new String(nums));
24
25 }
26 }

力扣670(java)-最大交换(中等)的更多相关文章

  1. 力扣—— Swap Nodes in Pairs(两两交换链表中的节点) python实现

    题目描述: 中文: 给定一个链表,两两交换其中相邻的节点,并返回交换后的链表. 你不能只是单纯的改变节点内部的值,而是需要实际的进行节点交换. 示例: 给定 1->2->3->4, ...

  2. 力扣1689. 十-二进制数的最少数目-C语言实现-中等难度题

    题目 传送门 如果一个十进制数字不含任何前导零,且每一位上的数字不是 0 就是 1 ,那么该数字就是一个 十-二进制数 .例如,101 和 1100 都是 十-二进制数,而 112 和 3001 不是 ...

  3. 力扣1438. 绝对差不超过限制的最长连续子数组-C语言实现-中等难度

    题目 传送门 文本 给你一个整数数组 nums ,和一个表示限制的整数 limit,请你返回最长连续子数组的长度,该子数组中的任意两个元素之间的绝对差必须小于或者等于 limit . 如果不存在满足条 ...

  4. 力扣1052. 爱生气的书店老板-C语言实现-中等难度

    题目 传送门 文本 今天,书店老板有一家店打算试营业 customers.length 分钟.每分钟都有一些顾客(customers[i])会进入书店,所有这些顾客都会在那一分钟结束后离开. 在某些时 ...

  5. 力扣算法经典第一题——两数之和(Java两种方式实现)

    一.题目 难度:简单 给定一个整数数组 nums 和一个整数目标值 target,请你在该数组中找出 和为目标值 target 的那 两个 整数, 并返回它们的数组下标. 你可以假设每种输入只会对应一 ...

  6. JS数据结构第六篇 --- 二叉树力扣练习题

    1.第226题:翻转二叉树 递归+迭代两种实现方式: /** 反转二叉树 * Definition for a binary tree node. * function TreeNode(val) { ...

  7. 力扣—Reorder List(重排链表)python实现

    题目描述: 中文: 给定一个单链表 L:L0→L1→…→Ln-1→Ln ,将其重新排列后变为: L0→Ln→L1→Ln-1→L2→Ln-2→… 你不能只是单纯的改变节点内部的值,而是需要实际的进行节点 ...

  8. 力扣——Reverse Nodes in k-Group(K 个一组翻转链表) python实现

    题目描述: 中文: 给你一个链表,每 k 个节点一组进行翻转,请你返回翻转后的链表. k 是一个正整数,它的值小于或等于链表的长度. 如果节点总数不是 k 的整数倍,那么请将最后剩余的节点保持原有顺序 ...

  9. 【力扣leetcode】-787. K站中转内最便宜的航班

    题目描述: 有 n 个城市通过一些航班连接.给你一个数组 flights ,其中 flights[i] = [fromi, toi, pricei] ,表示该航班都从城市 fromi 开始,以价格 p ...

  10. 【力扣】922. 按奇偶排序数组 II

    给定一个非负整数数组 A, A 中一半整数是奇数,一半整数是偶数. 对数组进行排序,以便当 A[i] 为奇数时,i 也是奇数:当 A[i] 为偶数时, i 也是偶数. 你可以返回任何满足上述条件的数组 ...

随机推荐

  1. WPF之属性

    目录 属性 依赖属性(Dependency Property) 依赖属性对内存的使用方式 声明和使用依赖属性 声明依赖属性 使用依赖属性 依赖属性的"属性" 依赖属性的" ...

  2. 精通 Grails: 用 Groovy 服务器页面(GSP)改变视图

    Groovy 服务器页面(Groovy Server Pages,GSP)将 Web 置于 Grails Web 框架之内.在 精通 Grails 系列的第三期中,Scott Davis 介绍了如何使 ...

  3. find第二天

    find第二天 1.找出/tmp目录下,属主不是root,且文件名不以f开头的文件 find /tmp ! -user root -a ! -name 'f*' 或者 find /tmp ! -use ...

  4. elasticsearch聚合桶排序、分页实战

    很多时候业务上需要分组排序分页的场景,类似于mysql的group by xxx limit 0 10.so,当数据同步到es后,相同的需求场景也出现了.背景:商品根据商品销量排序,销量数据是以sku ...

  5. copy 导入包含特殊符号的文本

    客户提供了一份数据记录需要导入数据库,但是文本中有一个列的内容是反斜杠"\" ,因为""是特殊的转义字符,需要使用两个"\"才能表示,如果直 ...

  6. 突然连不上Github或者连接超时的解决办法

    问题描述当进行仓库pull或者push时,报错如下(连接失败/被拒绝/超时等): Failed to connect to github.com port 443: Connection refuse ...

  7. #最大流#WOJ 124 Football Coach

    题目 有\(n\)支球队,互相之间已经进行了一些比赛.现在还有\(m\)场比赛未进行, 每场比赛胜者得2分,平局各得1分,负者不得分. 问是否存在一种方法使得球队\(n\)的得分比其他\(n-1\)支 ...

  8. #Splay#洛谷 1486 [NOI2004]郁闷的出纳员

    题目 分析 考虑加减工资直接打标记,查询第\(k\)多可以用平衡树, 删除有点恶心,这里考虑Splay,将需要删除的部分的后继splay到根节点并将左子树断边 代码 #include <cstd ...

  9. 深入理解 C++ 右值引用和移动语义:全面解析

    C++11引入了右值引用,它也是C++11最重要的新特性之一.原因在于它解决了C++的一大历史遗留问题,即消除了很多场景下的不必要的额外开销.即使你的代码中并不直接使用右值引用,也可以通过标准库,间接 ...

  10. 数据库SQL(MSSQLSERVER)服务启动错误代码3414

    昨天永和客户联系我,说他们的前台系统报错了,给我发了报错的图片.看到错误的第一眼就知道是数据库出问题了,连不上sql Server. 虽然知道是数据库出问题了,但是刚开始的时候没有打开SQL Serv ...