最大交换

该博客详细介绍了如何解决LeetCode中的第670题——最大交换。通过使用栈和贪心策略,博主阐述了如何找到并交换未处于尽可能高位的最大数字字符,以使整数最大化。在遍历过程中,如果当前数字比栈顶数字大并且位置更高,则进行交换。最后,博主给出了算法的时间复杂度为O(n)和空间复杂度为O(1)(因为栈最多存储10个元素)。
摘要由CSDN通过智能技术生成

leetcode 670 [medium]
中:最大交换
英:Maximum Swap
在这里插入图片描述

题解

1. 思路
  1. 要使得交换后数最大,那么就要让当前数中的处于尽可能高位的最大的数字字符交换到尽可能更高位
    例如对于 9379 是最大数字字符,但已经处于尽可能高位,而 7 是当前未处于尽可能高位的最大的数字字符
  2. 当满足 “未处于尽可能高位的最大的数字字符” 有多个时,要尽量选择原本处以更低位
    例如对于 9377 ,我们选择交换 个位的7 而不是 十位的7
2. 步骤(栈 + 贪心)
  1. 从末尾遍历num各位,若当前元素比栈顶元素大(空栈直接入栈),入栈。直到num头或者当前位为9。
  2. 从起始遍历num各位,比较当前位于栈顶元素的大小和位置关系
    (1)若当前元素比栈顶元素小,且满足当前元素在高位,栈顶元素在低位,则交换,返回结果;
    (2)若不满足高低位关系,则栈顶元素出栈,继续比较;
    (3)若栈为空,说明无需交换;
3. 时间复杂度:O(n)
4. 空间复杂度:O(1) 栈空间,最多只有10个元素
5. 实现
/**
 * @param {number} num
 * @return {number}
 */
var maximumSwap = function(num) 
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值