参考代码:
import java.util.Arrays; import java.util.Scanner; public class Main { public static void main(String[] args) { Scanner scanner = new Scanner(System.in); System.out.println(next(scanner.next())); } public static String next(String in) { char []s = in.toCharArray(); int i = s.length - 2; while(i >= 0 && s[i] >= s[i + 1]) i--; if(i < 0) return in; int j = s.length - 1; while(j > i && s[j] <= s[i]) j--; swap(s, i, j); Arrays.sort(s, i + 1, s.length); String res = ""; for(char c: s) res += c; return res; } public static void swap(char []arr, int i, int j) { char t = arr[i]; arr[i] = arr[j]; arr[j] = t; } }
0.0分
5 人评分
2004年秋浙江省计算机等级考试二级C 编程题(1) (C语言代码)浏览:1237 |
C二级辅导-统计字符 (C语言代码)浏览:541 |
川哥的吩咐 (C语言代码)浏览:875 |
C语言程序设计教程(第三版)课后习题11.1 (C语言代码)浏览:802 |
C语言训练-角谷猜想 (C语言代码)浏览:1705 |
这可能是一个假的冒泡法浏览:990 |
最小公倍数 (C语言代码)浏览:863 |
C语言程序设计教程(第三版)课后习题6.7 (C语言代码)浏览:520 |
C语言考试练习题_一元二次方程 (C语言代码)浏览:576 |
C语言程序设计教程(第三版)课后习题5.7 (C语言代码)浏览:633 |