大学IT网 - 最懂大学生的IT学习网站! QQ资料交流群:367606806
当前位置:大学IT网 > C#技巧 > 全排列输出 递归算法

全排列输出 递归算法

关键词:全排列输出递归算法  阅读(684) 赞(11)

[摘要]本文是对全排列输出 递归算法的讲解,对学习C#编程技术有所帮助,与大家分享。
        //将数组中指定的下标交换位置
        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);
                    }
                }
            }
        }   



相关评论