全排列输出 递归算法


早上刷微博的时候看到用程序输入全排列,一想发现自己没写过,不会,查资料吧。
百度百科上的解释,总结一下就是将当前的Index与后面的Index依次替换,直到结束!

        //将数组中指定的下标交换位置
        private static void 交换(char[] charlist, int left, int right)
        {
            var m = charlist[left];
            charlist[left] = charlist[right];
            charlist[right] = m;
        }

        private static void 递归(char[] charlist, int index, int length)
        {
    
            if (index == length - 1)    //当访问到列表的最后时将当前的顺序输出
            {
                for (int i = 0; i < charlist.Length; i++)
                {
                    Console.Write(charlist[i]);
                }
                Console.WriteLine();
            }
            else
            {
                //访问列表
                for (int i = index; i < length; i++)
                {
                    if (i != index)
                    {
                        交换(charlist, index, i);
                    }

                    递归(charlist, index + 1, length);

                    if (i != index)
                    {
                        交换(charlist, index, i);
                    }
                }
            }
        }    

优质内容筛选与推荐>>
1、RICH EDIT 控件 SDK 参考手册
2、HDOJ 2099 整除的尾数
3、C#中用HttpWebRequest中发送GET/HTTP/HTTPS请求
4、如何创建一个MVC模式的Joomla组件教程(九) 使用数据库下
5、Matrix


长按二维码向我转账

受苹果公司新规定影响,微信 iOS 版的赞赏功能被关闭,可通过二维码转账支持公众号。

    阅读
    好看
    已推荐到看一看
    你的朋友可以在“发现”-“看一看”看到你认为好看的文章。
    已取消,“好看”想法已同步删除
    已推荐到看一看 和朋友分享想法
    最多200字,当前共 发送

    已发送

    朋友将在看一看看到

    确定
    分享你的想法...
    取消

    分享想法到看一看

    确定
    最多200字,当前共

    发送中

    网络异常,请稍后重试

    微信扫一扫
    关注该公众号