zoukankan      html  css  js  c++  java
  • C#之冒泡排序

    算法描述

    1.由数组第一位数值开始与相邻数值进行比较,每次将比较后大的数值后移。最后将会把数组中最大值移动到数组最后;

    2.依次对数组中未排序序列重复进行比较排序,将比较后的最大值移动到未排序序列的最后;

    代码实现

         /*
            例如:对数组:{ 5,4,3,2,1 }进行比较 
    
            第一轮:{ 4,3,2,1,5 } :共比较四次
            第二轮:{ 3,2,1,4,5 } :共比较三次
            第三轮:{ 2,1,3,4,5 } :共比较二次
            第四轮:{ 1,2,3,4,5 } :共比较一次
            */
            public void Bubble(int[] arr)
            {
                int temp;
    
                bool flag;
    
                for (int i = 0; i < arr.Length - 1; i++) // 循环轮数
                {
                    flag = true;
    
                    for (int j = 0; j < arr.Length - i - 1; j++) // 比较次数
                    {
                        if (arr[j] > arr[j + 1])
                        {
                            temp = arr[j];
                            arr[j] = arr[j + 1];
                            arr[j + 1] = temp;
                            flag = false;
                        }
                    }
    
                    if (flag == true)
                    {
                        break;
                    }
                }
    
                Console.Write("冒泡排序:");
                foreach (int item in arr)
                {
                    Console.Write(item + " ");
                }
            }

    完整代码

    using System;
    
    namespace BubbleSortApplication
    {
        class Program
        {
            static void Main(string[] args)
            {
                var setArray = new SetArray();
                var bubbleSort = new BubbleSort();
    
                int[] arr = setArray.GetArray();
    
                bubbleSort.Bubble(arr);
    
                Console.ReadLine();
            }
        }
    
        class SetArray // 数组类
        {
            public int[] GetArray() 
            {
                int length; // 数组长度
                int[] arr; 
    
                Console.WriteLine("请输入数组长度:");
                length = Convert.ToInt32(Console.ReadLine());
    
                arr = new int[length];
    
                for (int i = 0; i <= length - 1; i++)
                {
                    Console.Write("请输入数组第{0}位数值:", i);
                    arr[i] = Convert.ToInt32(Console.ReadLine());
                }
    
                Console.Clear();
    
                Console.Write("arr[] = {");
                foreach (int item in arr)
                {
                    Console.Write(item + " ");
                }
                Console.Write("}
    ");
    
                return arr;
            }
        }
    
        class BubbleSort // 冒泡排序
        {
            public void Bubble(int[] arr)
            {
                int temp;
    
                bool flag;
    
                for (int i = 0; i < arr.Length - 1; i++)
                {
                    flag = true;
    
                    for (int j = 0; j < arr.Length - i - 1; j++)
                    {
                        if (arr[j] > arr[j + 1])
                        {
                            temp = arr[j];
                            arr[j] = arr[j + 1];
                            arr[j + 1] = temp;
                            flag = false;
                        }
                    }
    
                    if (flag == true)
                    {
                        break;
                    }
                }
    
                Console.Write("冒泡排序:");
                foreach (int item in arr)
                {
                    Console.Write(item + " ");
                }
            }
        }
    }
  • 相关阅读:
    [Ps]图层混合模式——排除
    [Swift]自定义View
    [Swift]Closures概念与使用
    [Swift]Class的概念与使用
    [Swift][OC]tableView去掉顶部空白
    html引用css的四种方法
    plSQL技巧:“tns:无法解析指定的连接标识符”问题详解
    桌面任务栏右侧的输入法状态(也就是语言栏)不见了,通常有以下几种解决方法:
    Myeclipse下java.lang.OutOfMemoryError: Java heap space的解决
    Tomcat使用相对路劲来访问
  • 原文地址:https://www.cnblogs.com/drift-code/p/8805967.html
Copyright © 2011-2022 走看看