当前位置: 首页 > news >正文

LeetCode:670. 最大交换(Java 贪心)

目录

670. 最大交换

题目描述:

实现代码与解析;

贪心

原理思路:


670. 最大交换

题目描述:

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

示例 1 :

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

示例 2 :

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

注意:

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

实现代码与解析;

贪心

class Solution {public int maximumSwap(int num) {char[] chars = String.valueOf(num).toCharArray();int n = chars.length;char maxn = chars[n - 1];int maxIdx = n - 1;int r = -1; // 右边需要交换的位置int l = -1; // 左边需要交换的位置for (int i = n - 1; i >= 0; i--) {             if (chars[i] < maxn) { // 说明此位置可能为左交换位置l = i; // 更新左交换位置r = maxIdx; // 获取当前位置若为左交换位置时的右交换位置,也就是当前位置右侧的数中最大值位置}if (maxn < chars[i]) { // 从右向左已经遍历过的值中的最大值maxn = chars[i]; // 更新最大值maxIdx = i; // 更新最大值位置} }if (l >= 0) { // 大于等于0才交换,因为有可能数据不用动swap(chars, l, r);}StringBuilder res = new StringBuilder();for (int i = 0; i < n; i++) {res.append(chars[i]);}int res2 = Integer.parseInt(res.toString());return res2;}public void swap(char[] chars, int l, int r) {char t = chars[r];chars[r] = chars[l];chars[l] = t;}
}

原理思路:

        无论是什么解法,肯定思想是一样的。

        此题是核心就是从左到右,找到 第一个其右侧数中的最大值比当前数大的位置,进行交换。

        所以你可以进行两次for循环直接暴力,但是可以优化,就如我写的代码一样。

从右向左,逆向,边求最大值,边比较(找出交换位置)。

        具体细节,代码注释很详细了。需要注意一下可能不需要交换就是最大了,判断一下。

http://www.lryc.cn/news/287932.html

相关文章:

  • 【STM32】STM32学习笔记-Unix时间戳(41)
  • 2016年认证杯SPSSPRO杯数学建模B题(第一阶段)低分辨率下看世界全过程文档及程序
  • 16、Kafka ------ SpringBoot 整合 Kafka (配置 Kafka 属性 及对应的 属性处理类 解析)
  • 【蓝桥杯选拔赛真题61】python偶数平方 第十五届青少年组蓝桥杯python 选拔赛比赛真题解析
  • 智能语音识别源码系统+语义理解+对话管理+语音合成 带完整的搭建教程
  • cdh6.3.2的hive配udf
  • 在DevEco开发工具中,使用Previewer预览界面中的UI组件
  • 【蓝桥杯冲冲冲】旅行计划
  • Ultraleap 3Di配置以及在 Unity 中使用 Ultraleap 3Di手部跟踪
  • HarmonyOS鸿蒙学习基础篇 - Text文本组件
  • pytorch学习笔记(十一)
  • 【并发编程】 synchronized的普通方法,静态方法,锁对象,锁升级过程,可重入锁,非公平锁
  • jQuery 删除元素 —— W3school 详解 简单易懂(十四)
  • 在 Linux 上搭建 Java 环境
  • 深度学习-Pytorch如何保存和加载模型
  • 2.数据结构 顺序表(自留笔记)
  • 将python打包成exe文件
  • 大数据处理,Pandas与SQL高效读写大型数据集
  • 【2024年5月备考新增】《软考高项论文专题 (2)论文背景(合集)》
  • Mysql复习1--理论基础+操作实践--更新中
  • 微信小程序打卡定位实现方案
  • 小迪安全23WEB 攻防-Python 考点CTF 与 CMS-SSTI 模版注入PYC 反编译
  • 计算机毕业设计 基于SpringBoot的律师事务所案件管理系统的设计与实现 Java实战项目 附源码+文档+视频讲解
  • 如何使用宝塔面板配置Nginx反向代理WebSocket(wss)
  • vulhub之redis篇
  • Lua简介和应用场景介绍
  • 【手写数据库toadb】10 开发数据库内核开发阶段-数据库模型
  • 02-Redis持久化、主从与哨兵架构详解
  • 无刷电机篇(一)直流无刷电机(BLDC)介绍
  • 【GitHub项目推荐--不错的Flutter项目】【转载】