不打印所有排列和程序出口。通过仅打印三个排列来停止递归;给定的字符串为“ ABCD”

    private static void myPermutations( String permutation,
                                    String str )
{
    if( str.length() == 0 )
        System.out.println( " -- >" + permutation );

    for( int i = 0; i < str.length(); i++ )
    {
        permutation = permutation + str.charAt( i );
        str = str.substring( 0, i ) + str.substring( i + 1 );
        myPermutations( permutation, str );
    }

}


但这有效。有什么不同 ?

private static void printPermutations( String candidate,
                                       String remaining )
{
    if( remaining.length() == 0 )
        System.out.println( "--> " + candidate );

    for( int i = 0; i < remaining.length(); i++ )
    {
        String newcandidate = candidate + remaining.charAt( i );
        String newremaining = remaining.substring( 0, i ) + remaining.substring( i + 1 );
        printPermutations( newcandidate, newremaining );
    }
}

最佳答案

在第一个实例中,您正在修改用于控制循环内部循环的变量:

for( int i = 0; i < str.length(); i++ )
{
    ...
    str = str.substring( 0, i ) + str.substring( i + 1 );
    ...
}


str变量处于for循环条件下。也可以在循环内部对其进行修改。

10-06 16:00