java 输入一个字符串,打印出该字符串中字符的所有排列

如题所述

import java.util.Scanner;

public class Demo001 {

public static void main(String[] args) {
        String str = "";
        
        Scanner scan = new Scanner(System.in);
        
        str = scan.nextLine();
        
        permutation(str.toCharArray(), 0);
    }

    public static void permutation(char[] str, int i) {
        if (i >= str.length)
            return;
        if (i == str.length - 1) {
            System.out.println(String.valueOf(str));
        } else {
            for (int j = i; j < str.length; j++) {
                char temp = str[j];
                str[j] = str[i];
                str[i] = temp;

                permutation(str, i + 1);

                temp = str[j];
                str[j] = str[i];
                str[i] = temp;
            }
        }
    }

}

运行结果:

温馨提示:内容为网友见解,仅供参考
第1个回答  2014-06-22
/*
 * 前人作品,思想供参考
 */
public class Main{
    
    public static void main(String[] args) {
        System.out.println(permutation("abcd").length);
        System.out.println(Arrays.toString(permutation("abcd")));
    }
    
    private static String[] permutation(String orginal){
        ArrayList list = new ArrayList();
        if(orginal.length() == 1){
            return new String[]{orginal};
        } else{
            for (int i = 0; i < orginal.length(); i++) {
                String s = orginal.charAt(i) + "";
                String result = "";
                String resultA = result + s;
                String leftS = orginal.substring(0, i) + orginal.substring(i + 1, orginal.length());
                for (String element : permutation(leftS)) {
                    result = resultA + element;
                    list.add(result);
                }
            }
            return (String[]) list.toArray(new String[list.size()]);
        }
    }
    
}

第2个回答  2014-06-22
排列组合啊?

java 输入一个字符串,打印出该字符串中字符的所有排列
实现思路:就是输入字符串后,通过递归的方式,循环每个位置和其他位置的字符。import java.util.Scanner; public class Demo001 { public static void main(String[] args) { String str = ""; Scanner scan = new Scanner(System.in); str = scan.nextLine(); permutation(str.t...

java 中,怎么打印出一个字符串的所有排列
把字符串转成数组,然后用foreach打印

Java中,怎么打印出一个字符串的所有排列?
首先,创建一个名为printPermutations的函数,它接收一个字符数组作为输入。函数从索引index开始,通过递归实现排列生成。在每次迭代中,它会交换arr[index]与arr[index+1],然后递归处理arr从index+2到末尾的子数组。当index等于字符串长度减一,意味着完成了一个完整的排列,这时将当前arr转换为字符串并...

Java编程——输入一段字符串,然后按字母顺序输出。并查询某个字母在这...
import java.util.Scanner;public class Dame1 { public static void main(String[] args) { Scanner san = new Scanner(System.in) ;System.out.println("输入一个字符串");String getString = san.nextLine();\/\/从键盘输入字符串 System.out.println("输入要查找的字符");String index = san...

从键盘上输入一个字符串,输出该字符串的n个字符后的所有字符怎么做
package baidu;import java.util.Scanner;public class Test {public static void main(String[] args) { Scanner in = new Scanner(System.in);String a = in.nextLine();\/\/键盘输入int n=5;String b = a.substring(5);\/\/字符串截取System.out.println(b);\/\/输出}}运行结果:输入字符...

java 输入字符串 输出升序和降序排序结果
public static void sortTest(){ System.out.println("Please input number, split with ',':");Scanner in=new Scanner(System.in);String readLine = in.nextLine(); \/\/读取键盘输入的一行(以回车换行为结束输入)String[] input = readLine.split(",");\/\/将输入的字符串根据','划分为...

java中怎样从键盘输入一个字符然后输出,求完整的程序
\/\/java貌似从控制台读入的都是字符串,一般都要进行转化。System.out.println(s);System.out.println("请输入一个字符:");char c = br.readLine().charAt(0);System.out.println(c);System.out.println("请输入一个双精度实数:");double d = Double.parseDouble(br.readLine()); \/\/转化...

求大神编一个简单的JAVA程序: 输入一个字符串,然后由程序统计并输出在该...
public class FruitImp { public static void main(String[] args) { String str = new Scanner(System.in).nextLine();\/\/用一个二维数组存放字符和对应的字数 \/\/用数组的缺点是空间浪费 可以用map 或别的代替这里就用数组简单点 int arr[][] = new int[2][str.length()];for(int i=0;...

JAVA怎么样输入一个string类字符串,并且可以把输入的字符以一个字符一行...
最佳答案 请笑纳 import java.util.Scanner;public class StringTest { public static void main(String[] args) { Scanner scanner = new Scanner(System.in); \/\/ 读取输入 String s = scanner.nextLine(); \/\/ 获取键盘输入的一行 \/\/遍历字符串中的所有字符 for (char c : s.toCharArray()...

java怎么将一个字符串5行5列输出
1、使用两个for循环分别控制输出的行数和列数,循环内部使用字符串的charAt()方法获取当前字符并输出。2、同时使用计数器count记录已经输出的字符个数,如果已经输出完字符串,则不再进行输出。3、最后在每行输出完毕后进行换行操作,以实现5行5列的输出效果。

相似回答