【华为OD题库-073】字符串变换最小字符串-java

题目

题目描述:

给定一个字符串s,最多只能进行一次变换,返回变换后能得到的最小字符串(按照字典序进行比较)。变换规则:交换字符串中任意两个不同位置的字符。
输入描述:

---串小写字母组成的字符串s
输出描述:

按照要求进行变换得到的最小字符串
备注:

s是都是小写字符组成

1<=s.length<=1000
示例1
输入:

abcdef
输出:

abcdef
说明:

abcdef已经是最小字符串,不需要交换
示例2
输入∶

bcdefa
输出:

acdefb
说明:

a和b进行位置交换,可以得到最小字符串

思路

将字符串中的字符按字典序排序(需要携带索引信息,所以list中可以考虑存放int[]的形式),得到list

遍历str,字符串逐位和list对比,如果第i位不一样,那么此时需要交换的位置就是,i和list.get(i)中存放的索引位置。

输出交换位置后的字符串即可

题解

java 复制代码
package hwod;

import java.util.ArrayList;
import java.util.List;
import java.util.Scanner;

public class TheMinStr {
    public static void main(String[] args) {
        Scanner sc = new Scanner(System.in);
        String str = sc.nextLine();
        System.out.println(theMinStr(str));
    }

    private static String theMinStr(String str) {
        List<int[]> list = new ArrayList<>();
        for (int i = 0; i < str.length(); i++) {
            list.add(new int[]{str.charAt(i), i});
        }
        list.sort((o1, o2) -> {
            if(o1[0]!=o2[0]) return o1[0] - o2[0];
            return o1[1] - o2[1];
        });
        for (int i = 0; i < str.length(); i++) {
            if (str.charAt(i) != list.get(i)[0]) {
                return swap(str, i, list.get(i)[1]);
            }
        }
        return str;
    }

    private static String swap(String str, int i, int j) {
        char[] chars = str.toCharArray();
        char t = chars[i];
        chars[i] = chars[j];
        chars[j] = t;
        return String.valueOf(chars);
    }
}

推荐

如果你对本系列的其他题目感兴趣,可以参考华为OD机试真题及题解(JAVA),查看当前专栏更新的所有题目。

相关推荐
毕设源码-钟学长4 分钟前
【开题答辩全过程】以 基于Java的医药进出口交易系统设计与实现为例,包含答辩的问题和答案
java·开发语言
Touch&4 分钟前
Windows11多个JDK版本(Java8、Java11、Java17、Java21)下载安装和切换
java·jdk·jdk多个版本切换
帮我吧智能服务平台13 分钟前
装备制造企业售后服务数字化:从成本中心到利润中心背景
java·前端·制造
历程里程碑15 分钟前
Proto3 三大高级类型:Any、Oneof、Map 灵活解决复杂业务场景
java·大数据·开发语言·数据结构·elasticsearch·链表·搜索引擎
蜜獾云15 分钟前
DDD 架构分层,MQ消息要放到那一层处理?
java·jvm·架构
夫礼者18 分钟前
【极简监控】核弹级排障利器:仿 Jenkins Script Console 打造免重启诊断“黑科技”
java·jenkins·监控·排错
空空潍21 分钟前
Spring AI 实战系列(四):Prompt工程深度实战
java·人工智能·spring·prompt
第二只羽毛23 分钟前
IO代码解释3
java·大数据·开发语言
weisian15128 分钟前
Java并发编程--24-死锁排查与性能调优:线上并发问题诊断指南(死锁,CPU飙升,内存溢出)
java·开发语言·arthas·死锁·火焰图·cpu飙升
-Da-30 分钟前
【操作系统学习日记】并发编程中的竞态条件与同步机制:互斥锁与信号量
java·服务器·javascript·数据库·系统架构