C#经典面试题:冒泡算法的使用

Hi i,m JinXiang


⭐ 前言 ⭐

本篇文章主要介绍C#经典面试题:冒泡算法的使用以及部分理论知识


🍉欢迎点赞 👍 收藏 ⭐留言评论 📝私信必回哟😁

🍉博主收将持续更新学习记录获,友友们有任何问题可以在评论区留言


目录

⭐什么是冒泡算法?

⭐为什么要使用冒泡?

⭐使用冒泡排序

1、代码示例

冒泡排序代码

 项目执行代码

2、执行结果

⭐使用冒泡排序的注意事项:(重点)

⭐冒泡算法使用总结:


⭐什么是冒泡算法?

冒泡算法是一种基础的排序算法。原理是多次遍历待排序的元素,每次比较相邻的两个元素,如果顺序不对则进行交换,直到所有元素都排好序为止。冒泡排序的特点是每一次遍历都会将最大(或最小)的元素沉到最后,并且每一次遍历都会有一个元素就位,因此被称为冒泡排序。

如下图所示:

⭐为什么要使用冒泡?

在实际应用中,冒泡算法可能并不是首选的排序算法,因为它的时间复杂度较高。然而,冒泡算法有以下几个优点:

  • 1. 简单易懂:冒泡算法的思想非常简单,容易理解和实现,即使对于初学者来说也比较容易掌握。
  • 2. 冒泡排序是稳定的:稳定性指的是如果两个元素的大小相等,经过排序后它们的相对位置保持不变。冒泡排序通过相邻元素的比较和交换,保证了相等元素的相对顺序不会改变,因此是稳定的排序算法。
  • 3. 适用于小规模数据:当待排序的数据规模比较小的时候,冒泡排序的效率并不会差到哪里去。由于冒泡排序的代码量较少且逻辑简单,对于数据量较小的情况下,可以使用冒泡排序来进行排序操作。

虽然冒泡算法在实际应用中可能并不是最优选择,但了解它的原理和特点对于理解排序算法的基本思想和思维方式是有帮助的。

⭐使用冒泡排序

1、代码示例

以下是使用冒泡排序算法进行数组排序的C#代码示例

冒泡排序代码
public void Bubble_sort(int[] List){int i, t=1, Temp;//t是目前冒泡的次数,就是小于n-1;i是数组中的第几位元素;Temp是中间替换量,大家都懂哒bool Finish = false;//康康你到底冒泡冒完没有,刚开始是没有,所以判为Fwhile((t<List.Length) && !Finish){Finish = true;for (i = 0; i < List.Length - t; i++){if (List[i] > List[i + 1]){Finish = false;Temp = List[i];List[i] = List[i + 1];List[i + 1] = Temp;//这里就是换数据的地方,其实可以简单化的,但是啊,我就是懒惰,聪明的,你,会写的。}}t++;}}
 项目执行代码
using System;namespace Bubble_Sort
{class Program{static void Main(string[] args){int[] Example = new int[] {-99,-4323,23,42,8848,114514,234 };Bubble bubble = new Bubble();bubble.Bubble_sort(Example);foreach(var item in Example){Console.Write(item+"," );}Console.Read();}}public class Bubble{public void Bubble_sort(int[] List){int i, t=1, Temp;//t是目前冒泡的次数,就是小于n-1;i是数组中的第几位元素;Temp是中间替换量,大家都懂哒bool Finish = false;//康康你到底冒泡冒完没有,刚开始是没有,所以判为Fwhile((t<List.Length) && !Finish){Finish = true;for (i = 0; i < List.Length - t; i++){if (List[i] > List[i + 1]){Finish = false;Temp = List[i];List[i] = List[i + 1];List[i + 1] = Temp;//这里就是换数据的地方,其实可以简单化的,但是啊,我就是懒惰,聪明的,你,会写的。}}t++;}}}
}

2、执行结果

排序后的数组效果:-432 -9 23 42 234 8848 114514

⭐使用冒泡排序的注意事项:(重点)

使用冒泡排序时需要注意以下几点:

1、冒泡排序是一种相邻元素比较和交换的算法,因此它是一种稳定排序算法,即相等元素的相对位置不会发生改变。

2、冒泡排序的时间复杂度为O(n^2),其中n为待排序数列的长度。因此,在处理大规模数据时,冒泡排序效率较低,不适合使用。

3、冒泡排序过程中,每一轮都会将一个最大(或最小)的元素"冒泡"到数列的末尾。因此,在第一次遍历后,最后一个元素已经是最大(或最小)的元素,无需再进行比较。

4. 如果待排序数列已经是有序的,冒泡排序仍然会进行比较和交换操作,但并不会改变数列的顺序。因此,可以通过设置一个标识位来判断数列是否已经有序,减少不必要的操作。

5. 冒泡排序是一种稳定的排序算法,相等元素的相对位置不会改变。因此,如果对于某些情况下需要保持相等元素的相对顺序时,冒泡排序是一种合适的选择。

综上所述,冒泡排序虽然简单易懂,但效率较低。在实际应用中,更推荐使用其他更高效的排序算法,如快速排序、归并排序等。

冒泡算法使用总结:

冒泡排序是一种简单但效率较低的排序算法。它的基本思想是通过相邻元素的比较和交换,将最大(或最小)的元素逐渐"冒泡"到数列的末尾,从而实现排序的目的。

具体步骤如下:

  • ①:从待排序的数列中,依次比较相邻的两个元素,如果前者比后者大(或小),则交换它们的位置。
  • ②:重复执行上述比较和交换的过程,直到整个数列排序完成。

冒泡排序的时间复杂度为O(n^2),其中n为待排序数列的长度。虽然冒泡排序的效率不高,但它有一些优点:简单易懂、稳定性好、适用于小规模数据等。因此,了解冒泡排序的原理和特点对于理解排序算法的基本思想和思维方式是有帮助的。

总结不易,希望宝宝们不要吝啬亲爱的👍哟(^U^)ノ~YO!如有问题,欢迎评论区批评指正😁

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/286613.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

telnet的交互原理(wireshark分析)

telnet的交互原理&#xff08;wireshark篇&#xff09; telnet的协议类型是tcp&#xff0c;他的密钥用的是明文的&#xff0c;容易被捕获&#xff0c;所以后来的windows基本弃用了telnet服务端但依然保留了客户端。 下面是他的交互抓包&#xff1a; 这里面的前三条运用的是tc…

IDEA tomcat内存不足

-Xms256m -Xmx256m -XX:MaxNewSize256m -XX:MaxPermSize256m

你对葡萄酒中的亚硫酸盐是不是有误解呢?

亚硫酸盐不会让某些人对酒产生不良的反应首先&#xff0c;让我谈谈欧洲生产的葡萄酒不含亚硫酸盐的观点&#xff0c;这在很大程度上是一种误解。虽然我听说过某些生产商在酿造葡萄酒时不添加亚硫酸盐&#xff0c;但这些确实是例外&#xff0c;添加亚硫酸盐是世界公认的酿酒传统…

Unity学习笔记(零基础到就业)|Chapter01:C#入门

Unity学习笔记&#xff08;零基础到就业&#xff09;&#xff5c;Chapter01:C#入门 前言一、控制台输入输出语句二、初识变量1.一些好用的tips2.变量声明的固定写法3.变量类型 三、变量的本质1.变量的存储空间2.变量的本质&#xff1a;2进制 四、变量的命名规范1.必须遵守的规则…

工行吉林省分行联合微信支付开展“反诈我在行”志愿服务活动

时值《中华人民共和国反电信网络诈骗法》颁布一周年&#xff0c;为积极响应国家号召&#xff0c;深入落实反电诈法&#xff0c;积极践行“金融为民”服务理念。12月7日&#xff0c;工商银行联合微信支付启动工行驿站“反诈我在行”志愿服务活动&#xff0c;普及反诈防诈与安全支…

C#中(, ||)与(, |)的区别

前言 在C#编程语言中&#xff0c;逻辑运算符用于组合和比较条件&#xff0c;以控制程序的流程和行为。在逻辑运算符中&#xff0c;有两对非常重要的运算符&#xff1a;&&和||、&和|。尽管它们看起来很相似&#xff0c;但其实它们有着不同的行为和使用场景。下面我们…

在Linux安装的Docker中开启IPv6

先在Linux中安装docker&#xff0c;然后在docker中开启IPv6。 安装docker 第一步&#xff0c;卸载旧版本docker。 若系统中已安装旧版本docker&#xff0c;则需要卸载旧版本docker以及与旧版本docker相关的依赖项。 命令&#xff1a;yum -y remove docker docker-client do…

MyBatis持久层框架

四、MyBatis持久层框架 目录 一、Mybatis简介 1. 简介2. 持久层框架对比3. 快速入门&#xff08;基于Mybatis3方式&#xff09; 二、日志框架扩展 1. 用日志打印替代sout2. Java日志体系演变3. 最佳拍档用法4. Lombok插件的使用 4.1 Lombok简介4.2 Lombok安装4.3 Lombok使用注…

zynqmp Linux + 裸机 (A53-0 Linux,A53-1 2 3 裸机大数据量实时处理,R5-0 协议处理,R5-1 屏幕显示逻辑等)填坑笔记

fpga 和arm 采用预留内存的方式&#xff0c;采用neon 协处理器只能做到 250M/S 的速度&#xff0c;预留内存采用mmap的方式&#xff0c;当读取内存页的时候采用缺页中断的方式&#xff0c;导致速度拖沓而且预留内存没有进行Linux系统的内存管理&#xff08;在系统内 memcpy的速…

JavaSE 泛型

目录 1 泛型类的定义1.1 为什么需要泛型1.2 泛型的概念1.3 泛型的分类 2 泛型类2.1 泛型类的定义2.2 泛型类的例子2.3 泛型类的实例化2.3.1 实例化语法2.3.2 裸类型(Raw Type) 2.4 泛型类的定义-类型边界2.5 泛型类的使用-通配符(Wildcards)2.5.1 基本概念2.5.2 通配符-上界2.5…

【09】ServiceEntry使用案例

案例背景 为了便于测试&#xff0c;我们用非网格化的名称空间中运行的应用来模拟运行于VM/萝服务上的外部服务&#xff0c;假设&#xff1a; 在网格外部运行nginx服务&#xff0c;有2个实例 Nginx2001:监听地址为172.29.1.201:8091&#xff0c;nginx版本为1.20nginx2002&#x…

c语言编写http服务器(Linux下运行)

参考文章&#xff1a;https://blog.csdn.net/baixingyubxy/article/details/125964986?spm1001.2014.3001.5506 上面是详细讲解&#xff0c;我这篇是总结了他的代码&#xff0c;因为他没给整体代码 所有代码&#xff1a; #include <stdio.h> #include <stdlib.h&g…