Java实现 蓝桥杯 历届真题 稍大的串

阅读: 评论:0

Java实现 蓝桥杯 历届真题  稍大的串

Java实现 蓝桥杯 历届真题 稍大的串

串可以按照字典序进行比较。例如:
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小时内删除。

标签:历届   真题   稍大   Java   蓝桥杯
留言与评论(共有 0 条评论)
   
验证码:

Copyright ©2019-2022 Comsenz Inc.Powered by ©

网站地图1 网站地图2 网站地图3 网站地图4 网站地图5 网站地图6 网站地图7 网站地图8 网站地图9 网站地图10 网站地图11 网站地图12 网站地图13 网站地图14 网站地图15 网站地图16 网站地图17 网站地图18 网站地图19 网站地图20 网站地图21 网站地图22/a> 网站地图23