排序之冒泡排序(C# C++)

目录

[1 冒泡排序的原理](#1 冒泡排序的原理)

[2 算法步骤](#2 算法步骤)

[3 代码示例](#3 代码示例)

3-1 C#代码示例

[3-2 C++代码示例](#3-2 C++代码示例)


1 冒泡排序的原理

冒泡排序(Bubble Sort)是一种简单的排序算法,它的基本思想是通过多次遍历待排序的数组,比较相邻元素的大小,并根据需要交换它们的位置,直到整个数组有序。

2 算法步骤

  1. 比较相邻元素:从数组的第一个元素开始,依次比较相邻的两个元素。如果前一个元素大于后一个元素,则交换它们的位置。
  2. 重复比较:对数组中的每一对相邻元素都进行上述比较和交换操作,直到数组的最后一个元素。这样,经过一轮比较后,最大的元素就会 "冒泡" 到数组的末尾。
  3. 缩小范围:重复上述步骤,但每次比较的范围逐渐缩小,因为每一轮排序都会将当前未排序部分的最大元素移动到末尾,所以下一轮排序时可以不再考虑这些已经排好序的元素。
  4. 终止条件:当某一轮排序中没有发生元素交换时,说明数组已经有序,排序过程可以提前终止。

3 代码示例

3-1 C#代码示例

根据算法步骤书写以下代码:(优化前)

cs 复制代码
using System;

namespace ConsoleApplication1
{
    internal class Program
    {
        private static int[] BubbleSort(int[] arr)
        {
            if (arr == null || arr.Length < 2) return arr;
            for (int e = arr.Length - 1; e > 0; e--)
                for (int i = 0; i < e; i++)
                    if (arr[i] > arr[i + 1])
                        Swap(arr,i,i+1);
            return arr;
        }
        private static void Swap(int[] arr, int i, int j)
        {
            arr[i] ^= arr[j];
            arr[j] = arr[i] ^ arr[j];
            arr[i] ^= arr[j];
        }
        public static void Main(string[] args)
        {
            int[] arr = { 2, 5, 7, 9, 3, 1, 4, 6, 8 };
            arr = BubbleSort(arr);
            foreach (var value in arr)
            {
                Console.WriteLine(value);
            }
        }
    }
}

仔细观察,可以发现该代码可以进行优化:

使用了异或运算来交换数组中两个元素的位置。异或运算的优点是不需要额外的临时变量,但存在一个问题:当ij指向数组的同一个位置时,异或交换会将该位置的元素置为 0。例如:

cs 复制代码
int a = 5;
a ^= a;  // a 变为 0

针对这个问题,我们对Swap方法添加对ij是否相等的检查。

原始代码在每一轮排序中都会进行完整的比较和交换操作,即使数组已经有序也会继续执行,这会浪费一些不必要的计算资源。针对这一问题,我们可以对其添加一个布尔变量swapped,用于记录每一轮排序中是否发生了元素交换。

优化后代码:

cs 复制代码
using System;

namespace ConsoleApplication1
{
    internal class Program
    {
        private static int[] BubbleSort(int[] arr)
        {
            if (arr == null || arr.Length < 2) return arr;
            for (int e = arr.Length - 1; e > 0; e--)
            {
                bool swapped = false;
                for (int i = 0; i < e; i++)
                    if (arr[i] > arr[i + 1])
                    {
                        Swap(arr, i, i + 1);
                        swapped = true;
                    }
                if(!swapped)break;
            }
            return arr;
        }
        private static void Swap(int[] arr, int i, int j)
        {
            if (i!= j)
            {
                arr[i] ^= arr[j];
                arr[j] = arr[i] ^ arr[j];
                arr[i] ^= arr[j];
            }
        }
        public static void Main(string[] args)
        {
            int[] arr = { 2, 5, 7, 9, 3, 1, 4, 6, 8 };
            arr = BubbleSort(arr);
            foreach (var value in arr)
                Console.WriteLine(value);
        }
    }
}

运行测试:

3-2 C++代码示例
cpp 复制代码
#include <iostream>
#include <vector>

// 交换数组中两个元素的位置
void Swap(std::vector<int>& arr, int i, int j) {
    if (i != j) {
        arr[i] ^= arr[j];
        arr[j] = arr[i] ^ arr[j];
        arr[i] ^= arr[j];
    }
}

// 冒泡排序函数
std::vector<int> BubbleSort(std::vector<int> arr) {
    if (arr.size() < 2) return arr;
    for (int e = arr.size() - 1; e > 0; e--) {
        bool swapped = false;
        for (int i = 0; i < e; i++) {
            if (arr[i] > arr[i + 1]) {
                Swap(arr, i, i + 1);
                swapped = true;
            }
        }
        if (!swapped) break;
    }
    return arr;
}

int main() {
    std::vector<int> arr = { 2, 5, 7, 9, 3, 1, 4, 6, 8 };
    arr = BubbleSort(arr);
    for (int value : arr) {
        std::cout << value << std::endl;
    }
    return 0;
}

测试运行:

相关推荐
枕星而眠5 分钟前
C++ 面向对象核心机制深度解析:多态性、虚函数、虚继承与 final 类
运维·开发语言·c++·后端
智者知已应修善业30 分钟前
【51单片机8个LED,已经使用了D1D2,怎么样在不动D1D2的前提下实现D6~D8的流水灯】2024-1-19
c++·经验分享·笔记·算法·51单片机
Evand J31 分钟前
【MATLAB例程】自适应渐消扩展卡尔曼滤波(AFEKF)三维雷达目标跟踪|效果已调优,附下载链接和运行结果,代码直接运行即可
开发语言·算法·matlab·目标跟踪·卡尔曼滤波·自适应滤波·代码定制
坚果派·白晓明32 分钟前
鸿蒙PC适配实战:simdjson 三方库移植攻略与 AtomCode Skills 提效之道
c++·harmonyos·三方库·skills·atomcode·c/c++三方库·c/c++三方库适配
爱装代码的小瓶子33 分钟前
3. 设计buffer模块
linux·服务器·开发语言·c++·php
郝学胜-神的一滴33 分钟前
Qt 高级开发 027: QTabWidget自定义样式表美化实战
开发语言·c++·qt·程序人生·软件构建·用户界面
keykey6.33 分钟前
迁移学习实战:用预训练模型做图像分类
开发语言·人工智能·深度学习·机器学习
双河子思34 分钟前
《代码整洁之道》——读书笔记(持续更新)
开发语言·c++·c#
川冰ICE34 分钟前
JavaScript实战②|电商网站交互效果,轮播图与购物车
开发语言·javascript·交互
listhi52036 分钟前
基于 Qt 5.8.0 的串口调试助手
开发语言·qt