C# 入门算法“冒泡排序“ 升序 降序 最大值 最小值 平均值

简介: C# 入门算法“冒泡排序“ 升序 降序 最大值 最小值 平均值

效果图:

冒泡排序:

冒泡排序 是一种 排序 算法 就是把 数字 小的和 数字 大的进行位置的调换 部分的公司招聘 也拿来当做 面试题 …

为什么叫冒泡排序?

冒泡排序就是 和水里面产生的气泡一样从小到大的慢慢的升起 所以就叫冒泡排序

完整代码:

排序

int[] arr = {12,18,4,6,80,10,14,12,66,19};
            for (int i = 0; i < arr.Length; i++)
            {
                for (int j=0;j<arr.Length-1;j++)
                {
                  //大于号就是 大 到 小
                    if (arr[i] < arr[j])
                    {
                        int number = arr[i];
                        arr[i] = arr[j];
                        arr[j] = number;
                    }
                }                  
            }
            foreach (int look in arr)
            {
                Console.Write(look+" ");
            }
            Console.ReadKey();

定义进行排序的数组:

升序: 小的数字到大的数字

降序: 大的 到 小的

int[] arr = {12,18,4,6,80,10,14,12,66,19};

可以看见现在的顺序是非常的凌乱的

使用循环体进行换位置:

for (int i = 0; i < arr.Length; i++)
            {
                for (int j=0;j<arr.Length-1;j++)
                {
                    if (arr[i] < arr[j])
                    {
                        int number = arr[i];
                        arr[i] = arr[j];
                        arr[j] = number;
                    }
                }                  
            }

因为要进行 两个 元素的 对比 所以需要使用 两个循环体 进行 元素之间的对比

第一个循环跑一次 而内循环就需要跑 10次(根据元素的个数决定)

if (arr[i] < arr[j])
   {
int number = arr[i];
arr[i] = arr[j];
 arr[j] = number;

如果[i]号元素小于[j]号 两个元素之间就进行换位置 其中"number"是中间变量 存储[i]值

当然如果你想通过 不使用第三方 变量 进行交换 也可以这样

if (arr[i] < arr[j])
 {
 arr[i] = arr[i]+arr[j];
 arr[j] = arr[i]-arr[j];
 arr[i] = arr[i] - arr[j];
 }

额外知识:

不使用第三方 变量 进行 两个 变量的交换

int a =10;
int  b =20;
 a =a+b;
 b =a-b;
 a=a-b;

这样也可以达到一模一样的效果 原理还是那样 只是变的复杂了一点

但是不建议这里写 因为…简单的都变复杂化了

假设这是第一次循环:

i的每一个元素 j 都会一个个对比

上面演示的是 升序

降序:

//变成大于号
if (arr[i] > arr[j])
 {
int number = arr[i];
 arr[i] = arr[j];
  arr[j] = number;
  }

变动一个符号即可


当然如果你是初学者,看不懂 双重 循环体 也可以使用Arrar的静态方法

进行

int[] arr = {12,18,4,6,80,10,14,12,66,19};
 Array.Sort(arr);
 //一建对数组 进行升序的排序 

效果一模一样

这个静态方法 提供了 升序的排序 但他没有提供 降序的方法

不过可以用他的另外一个方法 进行数组反转的 来达到一样的效果

int[] arr = {12,18,4,6,80,10,14,12,66,19};
Array.Sort(arr);
 //升序排序
 Array.Reverse(arr);
 //数祖反转达到 降序效果


数组最小值:

求一个数组里面的 最小 一位数

比较简单

int[] arr = {-12,18,4,26,100,10,14,12,66,-19};
            int max = 0;
            for (int i = 0; i < arr.Length; i++)
            {    //大于号就是 最大值
                if (arr[i] <max)
                {
                    max = arr[i];
                    }
            }
            Console.WriteLine(max);
            Console.ReadKey();


平均值:

整数/个数字

int[] arr = {-12,18,4,26,100,10,14,12,66,-19};
            int max = 0;
            for (int i = 0; i < arr.Length; i++)
            {
                max +=arr[i];
            }
            Console.WriteLine(max/arr.Length-1);
            Console.ReadKey();


练习题:

生成10个随机数 进行 升序排序 算出 最大值 最小值 平均值

答案:

Random r = new Random();
            int[] arr = new int[10];
            int average = 0;
            for (int i = 0; i < arr.Length; i++)
            {
                arr[i] = r.Next(-10,100);
            }      
        for (int i = 0; i < arr.Length; i++)
        {
           average += arr[i];
            for (int j = 0; j < arr.Length - 1; j++)
            {
                if (arr[i] < arr[j])
                {
                    int tmp = arr[i];
                    arr[i] = arr[j];
                    arr[j] = tmp;                    
                }
            }         
        }
        foreach (int number in arr)
        {
            Console.Write(number + " ");
        }
        Console.WriteLine("\n最小值是:" + arr[0]);
         Console.WriteLine("最大值是:" + arr[arr.Length-1]);
        Console.WriteLine("平均值是:" + (average / arr.Length - 1));
            Console.ReadKey();

纯手打,点个赞呗~

相关文章
|
2月前
|
开发框架 .NET API
RESTful API 设计与实现:C# 开发者的一分钟入门
【10月更文挑战第5天】本文从零开始,介绍了如何使用 C# 和 ASP.NET Core 设计并实现一个简单的 RESTful API。首先解释了 RESTful API 的概念及其核心原则,然后详细说明了设计 RESTful API 的关键步骤,包括资源识别、URI 设计、HTTP 方法选择、状态码使用和错误处理。最后,通过一个用户管理 API 的示例,演示了如何创建项目、定义模型、实现控制器及运行测试,帮助读者掌握 RESTful API 的开发技巧。
80 7
|
25天前
|
搜索推荐 Python
利用Python内置函数实现的冒泡排序算法
在上述代码中,`bubble_sort` 函数接受一个列表 `arr` 作为输入。通过两层循环,外层循环控制排序的轮数,内层循环用于比较相邻的元素并进行交换。如果前一个元素大于后一个元素,就将它们交换位置。
125 67
|
2月前
|
算法
【❤️算法笔记❤️】-每日一刷-23、合并 K 个升序链表
【❤️算法笔记❤️】-每日一刷-23、合并 K 个升序链表
36 0
|
2月前
|
搜索推荐
冒泡排序算法
【10月更文挑战第19天】冒泡排序是一种基础的排序算法,虽然在实际应用中可能不是最优的选择,但对于理解排序算法的基本原理和过程具有重要意义。
|
1月前
|
机器学习/深度学习 算法 Python
机器学习入门:理解并实现K-近邻算法
机器学习入门:理解并实现K-近邻算法
36 0
|
1月前
|
程序员 C# 图形学
全面的C#/.NET自学入门指南
全面的C#/.NET自学入门指南
|
1月前
|
算法 C#
C#常见的四种经典查找算法
C#常见的四种经典查找算法
|
1月前
|
算法 C# 索引
C#线性查找算法
C#线性查找算法!
|
2月前
|
存储 消息中间件 NoSQL
Redis 入门 - C#.NET Core客户端库六种选择
Redis 入门 - C#.NET Core客户端库六种选择
69 8
|
2月前
|
存储 算法 C#
C#哈希查找算法
C#哈希查找算法