码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 力扣leetcode 670. 最大交换


    文章目录

    • 题目链接与描述
    • 关键词: 数值交换 贪心
    • 方法一:
      • 运行截图
      • 代码
    • 结尾

    在这里插入图片描述

    题目链接与描述

    https://leetcode.cn/problems/maximum-swap/

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

    示例 1 :

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

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

    给定数字的范围是 [0, 10^8]

    关键词: 数值交换 贪心

    方法一:

    运行截图

    在这里插入图片描述

    代码

    使数字最大,很容易想到把数值大的往前排,数值小的往后排, 最暴力的解法: 我们要最大,那就把数字最大的排前面,保证前面的都是最大的,把数字遍历一遍,取后n位最大的出来对比即可

    转换思路,因为最大的数一定时按大的前,小的在后;且我们只能拿一个,所以只需要找到最大的那个数,比前方小的靠前的值交换即可

    
    	public int maximumSwap(int num) {
    		char[] charArray = String.valueOf(num).toCharArray();
    		int n = charArray.length;
    		int maxIdx = n - 1;
    		int idx1 = -1, idx2 = -1;
    		for (int i = maxIdx; i >= 0; i--) {
    			if (charArray[i] > charArray[maxIdx]) {
    				maxIdx = i;
    			} else if (charArray[i] < charArray[maxIdx]) {
    				idx1 = i;
    				idx2 = maxIdx;
    			}
    		}
    		if (idx1 >= 0) {
    			swap(charArray, idx1, idx2);
    			return Integer.parseInt(new String(charArray));
    		} else {
    			return num;
    		}
    	}
    	public void swap(char[] charArray, int i, int j) {
    		char temp = charArray[i];
    		charArray[i] = charArray[j];
    		charArray[j] = temp;
    	}
    
    
    
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29

    结尾

    欢迎评论区交流,每日打卡,冲冲冲!!!

  • 相关阅读:
    java基础·小白入门(一)
    数据库1~4NF+ BCNF
    第十四届蓝桥杯python第二期模拟赛
    vim学习手册
    Flink学习20:算子介绍reduce
    博途PLC增量式PID(支持正反作用和归一化输出)
    十年老安卓开发转车载行业,成功斩下50K*13offer的历程经历
    mycat 垂直分库与水平分表使用详解
    SSL双向认证-SpringBoot项目
    Python NLP教程之知识图谱,从文本构建知识,实现从文本或在线文章中提取知识库的管道(教程含源码)
  • 原文地址:https://blog.csdn.net/qq_35530042/article/details/126826327
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号