串可以按照字典序进行比较。例如:
abcd 小于 abdc
如果给定一个串,打乱组成它的字母,重新排列,可以得到许多不同的串,在这些不同的串中,有一个串刚好给定的串稍微大一些。科学地说:它是大于已知串的所有串中最小的串。你的任务就是求出这个“稍大的串”。
例如:
输入串:
abfxy
程序应该输出:
abfyx
再例如:
输入串:
ayyyxxff
程序应该输出:
fafxxyyy
fyyyxxaa
数据规模约定:
输入的串不超过1000个字符。
特例:
如果已知的串已经是所有重组串中最大的,则原样输出读入的那个串。
资源约定:
峰值内存消耗(含虚拟机) < 256M
CPU消耗 < 1000ms
请严格按要求输出,不要画蛇添足地打印类似:“请您输入…” 的多余内容。
所有代码放在同一个源文件中,调试通过后,拷贝提交该源码。
注意:不要使用package语句。不要使用jdk1.7及以上版本的特性。
注意:主类的名字必须是:Main,否则按无效代码处理。
import java.util.Arrays;
import java.util.Scanner;public class Main {public void getResult(String A) {int len = A.length();int i = len - 1;for(;i >= 1;i--)if(A.charAt(i - 1) < A.charAt(i))break;if(i == 0) {System.out.println(A);return;}char temp = A.charAt(i - 1);char[] arrayB = A.substring(i).toCharArray();Arrays.sort(arrayB);for(int j = 0;j < arrayB.length;j++)if(arrayB[j] > temp) {char a = arrayB[j];arrayB[j] = temp;temp = a;break;}StringBuilder result = new StringBuilder(A.subSequence(0, i - 1));result.append(temp);for(int j = 0;j < arrayB.length;j++)result.append(arrayB[j]);System.out.println(result);}public static void main(String[] args) {Main test = new Main();Scanner in = new Scanner(System.in);String A = in.next();Result(A);}
}
本文发布于:2024-02-04 08:55:12,感谢您对本站的认可!
本文链接:https://www.4u4v.net/it/170703530654145.html
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。
留言与评论(共有 0 条评论) |