没事练习一下算法:全排列的递归算法。

using  System;

namespace  TotalSort
{
    
/// <summary>
    
/// 全排列的递归算法
    
/// </summary>

    class Class1
    
{
        
/// <summary>
        
/// 应用程序的主入口点。
        
/// </summary>

        [STAThread]
        
static void Main(string[] args)
        
{
            
//char[] s = "abcdefghijklmnopqrstuvwxyz".ToCharArray();
            char[] s = "abcde".ToCharArray();
            TotalSort(s, 
0);            
            Console.WriteLine(
"/n/n总数:{0}", resultCount);
            Console.ReadLine();
        }


        
static int resultCount = 0;

        
public static void TotalSort(char[] list, int start) {
            
int end = list.Length - 1;

            
if (start == end) {
                resultCount
++;
                Console.WriteLine(list);
            }

            
else {
                
for (int i = start; i <= end; i++{
                    
char[] temp = new char[list.Length];
                    list.CopyTo(temp, 
0);
                    
char tempc = temp[start];
                    temp[start] 
= temp[i];
                    temp[i] 
= tempc;

                    TotalSort(temp, start 
+ 1);
                }

            }

        }

    }

}


本来想测试 a - z 的全排列,但估算了一下数目相当惊人,只好作罢。
(这个数目是 26!)

采用了递归仅仅是为了锻炼算法,效率肯定是很低的。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值