zoukankan      html  css  js  c++  java
  • 递归生成随机数组,冒泡排序生成的数组

    递归生成随机数组,冒泡排序生成的数组,学习心得(直接贴代码)。。。

      class Program
        {
            static void Main(string[] args)
            {   
                #region  递归:兔子算法、生成数组 冒泡排序
                Console.WriteLine("兔子算法:");
                for (var i = 0; i <= 10; i++)
                    Console.Write(FnRabbit(i) + "   ");//	表示tab 
    回车 
    换行
                Console.WriteLine("");
    
                Console.WriteLine("递归数组:");
    var arr = FnGetArr(10, 20, new List<int>()); foreach (var a in arr) Console.Write(a + " "); Console.WriteLine("");
    Console.WriteLine(
    "冒泡排序:"); var arr1 = FnMaoPao(arr,"DESC"); foreach (var a in arr1) Console.Write(a + " "); #endregion Console.ReadKey(); }//兔子算法 static int FnRabbit(int quantity) //f(n)=f(n-1)+fn(n-2) 简称兔子算法 { return quantity <= 0 ? 0 : quantity.Equals(1) ? 1 : quantity.Equals(2) ? 2 : FnRabbit(quantity - 1) + FnRabbit(quantity - 2); } //递归生成数组 static Random ram = new Random(); static int[] FnGetArr(int min, int max, List<int> list) { var count = max - min + 1;//这边设置+1的话,取随机数的话也要加1,否则会死循环 if (list.Count < count) { var temp = ram.Next(min, max + 1);//返回的随机数的上界(随机数不能取该上界值)。maxValue 必须大于或等于 minValue。 if (!list.Contains(temp)) list.Add(temp); FnGetArr(min, max, list); } return list.ToArray(); } //冒泡 static int[] FnMaoPao(int[] arr, string sort) { for (var i = 0; i < arr.Length - 1; i++)//第一次的话,就是直接把最大或最小的放到最末尾。第二次的话只需要把最值的放到倒数第二个 { for (var j = 0; j < arr.Length - 1 - i; j++)//少一个数就晒一次循环 { if (sort.ToUpper().Equals("ASC")) { if (arr[j] > arr[j + 1]) { var temp = arr[j]; arr[j] = arr[j + 1]; arr[j + 1] = temp; } } else { if (arr[j] < arr[j + 1]) { var temp = arr[j]; arr[j] = arr[j + 1]; arr[j + 1] = temp; } } } } return arr; } }
  • 相关阅读:
    0316-复利计算更新
    实验一 了解和掌握操作系统
    复利计划1.0
    0916 词法分析(2)
    0916词法分析
    0909 编译原理 第1次上机
    单元测试代码
    单元测试
    实验一:命令解释程序
    《构建之法》现代软件工程第1、2、3章读后感
  • 原文地址:https://www.cnblogs.com/huage-1234/p/7240862.html
Copyright © 2011-2022 走看看