题目描述:
- 给定一个字符串s,最多只能进行一次变换,返回变换后能得到的最小字符串(按照字典序进行比较)。
- 变换规则:交换字符串中任意两个不同位置的字符。
输入描述:
- 一串小写字母组成的字符串s。
输出描述:
- 按照要求进行变换得到的最小字符串。
备注:
- s是都是小写字符组成
- 1<=s.length<=1000
示例
输入:abcdef
输出:abcdef
说明:abcdef已经是最小字符串,不需要交换
输入:bcdefa输出:acdefb
说明:a和b进行位置交换,可以得到最小字符串
代码:
import java.util.Scanner;
public class main{
public static void main(String[] args) {
Scanner sc = new Scanner(System.in);
String str = sc.nextLine();
char[] cArr = str.toCharArray();
char tmp = cArr[0];
int tmpIndex = 0;
for (int left = 0; left < cArr.length; left++) {
tmp = cArr[left];
tmpIndex = left;
for (int i = left; i < cArr.length; i++) {
if (cArr[i] < tmp) {
tmp = cArr[i];
tmpIndex = i;
}
}
if (tmpIndex != left) {
cArr[tmpIndex] = cArr[left];
cArr[left] = tmp;
break;
}
}
str = String.valueOf(cArr);
System.out.println(str);
}
}
版权声明:本文为qiudechao1原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。