读书人

一道C#算法题求高效算法。解决方法

发布时间: 2012-03-28 15:40:03 作者: rapoo

一道C#算法题,求高效算法。
一道面试题,如下:

有数组1,2,3,4,5,6,7。按照各种不同的顺序打印出来,其中4不能在第3位,3和5不能相邻。求最高效算法。

[解决办法]

C# code
        static IEnumerable<string> Arrange(string source)        {            for (int i = 0; i < source.Length; i++)            {                if (source.Length == 1)                {                    yield return source;                }                else                {                    foreach (var x in Arrange(source.Substring(0, i) + source.Substring(i + 1)))                    {                        yield return source[i] + x;                    }                }            }        } 

读书人网 >C#

热点推荐