【Leetcode】670. 最大交换

文章目录

题目

题目链接

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

示例1:

输入: 2736

输出: 7236

解释: 交换数字2和数字7。
示例2:

输入: 9973

输出: 9973

解释: 不需要交换。
注意:

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

思路

今天又是一道简单题目,给你一个数字,你可以选择把这个数字中的任意两位进行替换或者不进行操作,使得这个数字尽可能的大,返回这个数字。数字范围也很小也就是108而已。要想使这个数字尽可能的大当然要要把最大的数字放到最前面了,那如果一开始这个数字就是从高到低就不需要进行操作了。最后因为涉及到数字之间的转换,所以可以转换为字符串来进行操作,这样方便一点,这里就可以用到to_string

to_string

用于将数字类型转换为字符串类型。这个函数通常用于将整数、浮点数等基本数据类型转换为它们的字符串表示形式。时间复杂度通常是线性的,即 O(n)

代码

c++ 复制代码
class Solution {
public:
    int maximumSwap(int num) {
        string str = to_string(num);
        string s = str;
        sort(s.rbegin(),s.rend());
        if(str == s)
        {
            return num;
        }
        for(int i = 0;i < str.size();i++)
        {
            if(str[i] != s[i])
            {
                int idx;
                for(int j = i;j < str.size();j++)
                {
                    if(str[j] == s[i])
                    {
                        idx = j;
                    }
                }
                swap(str[idx],str[i]);
                break;
            }
        }
        int target = 0;
        for(int i = 0;i < str.size();i++)
        {
            target = target * 10 + (str[i] - '0');
        }
        return target;
    }
};

结果

相关推荐
铅笔小新z29 分钟前
C++入门指南:开启你的编程之旅
开发语言·c++
大胆飞猪3 小时前
递归、剪枝、回溯算法---全排列、子集问题(力扣.46,78)
算法·leetcode·剪枝
Kisorge5 小时前
【电机控制】基于STM32F103C8T6的二轮平衡车设计——LQR线性二次线控制器(算法篇)
stm32·嵌入式硬件·算法
铭哥的编程日记6 小时前
深入浅出蓝桥杯:算法基础概念与实战应用(二)基础算法(下)
算法·职场和发展·蓝桥杯
Swift社区6 小时前
LeetCode 421 - 数组中两个数的最大异或值
算法·leetcode·职场和发展
cici158746 小时前
基于高光谱成像和偏最小二乘法(PLS)的苹果糖度检测MATLAB实现
算法·matlab·最小二乘法
_OP_CHEN7 小时前
Linux网络编程:(八)GCC/G++ 编译器完全指南:从编译原理到实战优化,手把手教你玩转 C/C++ 编译
linux·运维·c++·编译和链接·gcc/g++·编译优化·静态链接与动态链接
StarPrayers.8 小时前
自蒸馏学习方法
人工智能·算法·学习方法
大锦终8 小时前
【动规】背包问题
c++·算法·动态规划
犯困的土子哥8 小时前
C++:哈希表
c++·哈希算法