zoukankan      html  css  js  c++  java
  • 没事练习一下算法:全排列的递归算法。

    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!)

    采用了递归仅仅是为了锻炼算法,效率肯定是很低的。
  • 相关阅读:
    Java小白集合源码的学习系列:Vector
    Java小白集合源码的学习系列:LinkedList
    707.设计双向链表
    Java小白集合源码的学习系列:ArrayList
    Leetcode动态规划【简单题】
    小白学Java:老师!泛型我懂了!
    小白学Java:包装类
    Java面向对象之异常详解
    Java面向对象之异常【一】
    浅谈Java中接口与抽象类的异同
  • 原文地址:https://www.cnblogs.com/RChen/p/178268.html
Copyright © 2011-2022 走看看