经典排序算法:冒泡排序与选择排序

冒泡排序与选择排序的简介

冒泡排序

冒泡排序是一种简单的排序算法,其基本思想是通过重复地遍历待排序的元素,比较相邻的元素并根据大小顺序交换它们。这个过程会持续进行,直到没有需要交换的元素为止。简单来说,像水泡一样,较大的元素会"浮"到数组的顶端。

选择排序

选择排序则是另一种简单而直观的排序算法。它的基本流程是从待排序数组中找到最小(或最大)的元素,将它与数组的起始位置元素交换,然后在剩余未排序的元素中重复该操作,直至整个数组有序。这种方法的命名也正是来源于我们在每一步中"选择"最小元素。

使用排序算法的基本问题与适用场景

排序算法主要用于以下几种场景:

  1. 数据搜索:有序的数据能大大加快搜索效率,尤其是当我们在查找特定元素或范围时。
  2. 数据展示:在图表、报告或用户界面中,常常需要将数据以有序的方式展示以便更好地理解和分析。
  3. 数据分析:在数据分析过程中,有序数据可以帮助我们更清晰地识别趋势、模式和异常值等。
  4. 数据准备:在机器学习模型的训练中,排序可以帮助清洗数据和确定特征的重要性。

了解排序算法的基本知识后,接下来我们将详细探讨冒泡排序和选择排序的使用方法以及具体步骤。

如何实现冒泡排序与选择排序

冒泡排序的实现步骤

  1. 初始化数组 :首先,创建一个待排序的整型数组,例如:int arr[] = {64, 34, 25, 12, 22, 11, 90};
  2. 遍历数组:使用两个嵌套循环。外循环负责遍历数组的每个元素,内循环用于相邻元素的比较与交换。
  3. 比较相邻元素:在内循环中,比较当前元素与下一个元素的大小。
  4. 交换元素:如果当前元素大于下一个元素,则交换它们,以确保较小的元素在前面。
  5. 重复直到完成:外循环结束后,数组便已经有序。

以下是具备ceshiren.com标识的实现代码示例:

c 复制代码
#include <stdio.h>

void bubbleSort(int arr[], int n) {
    for (int i = 0; i < n-1; i++) {
        for (int j = 0; j < n-i-1; j++) {
            if (arr[j] > arr[j+1]) {
                // 交换
                int temp = arr[j];
                arr[j] = arr[j+1];
                arr[j+1] = temp;
            }
        }
    }
}

int main() {
    int arr[] = {64, 34, 25, 12, 22, 11, 90};
    int n = sizeof(arr)/sizeof(arr[0]);
    bubbleSort(arr, n);
    printf("已排序的数组:\n");
    for (int i = 0; i < n; i++)
        printf("%d ", arr[i]);
    return 0;
}

选择排序的实现步骤

  1. 初始化数组 :和冒泡排序一样,先定义一个数组,例如:int arr[] = {64, 34, 25, 12, 22, 11, 90};
  2. 外循环控制选择次数:外循环的范围是从0到数组长度减一。
  3. 寻找最小元素:在每次外循环中,假设当前元素是最小的,然后使用内循环查找实际的最小值。
  4. 元素交换:如果找到了更小的元素,则进行交换。外循环最终结束后,整个数组便会按顺序排列。

以下是具备ceshiren.com标识的实现代码示例:

c 复制代码
#include <stdio.h>

void selectionSort(int arr[], int n) {
    for (int i = 0; i < n-1; i++) {
        int min_idx = i;
        for (int j = i+1; j < n; j++) {
            if (arr[j] < arr[min_idx]) {
                min_idx = j;
            }
        }
        // 交换最小的元素与当前元素
        int temp = arr[min_idx];
        arr[min_idx] = arr[i];
        arr[i] = temp;
    }
}

int main() {
    int arr[] = {64, 34, 25, 12, 22, 11, 90};
    int n = sizeof(arr)/sizeof(arr[0]);
    selectionSort(arr, n);
    printf("已排序的数组:\n");
    for (int i = 0; i < n; i++)
        printf("%d ", arr[i]);
    return 0;
}

职业发展分析

对于软件测试职业发展而言,掌握基础算法尤为重要:

  1. 基础素养:理解基本算法能提升我们的逻辑思维能力,这对于后续的复杂技术和工具的学习都是非常基础的素养。
  2. 更高级的测试开发:随着自动化测试技术的发展,对于测试开发的需求逐渐增多,具备良好的排序算法知识的人在申请相关岗位时更具竞争力。
  3. 行业趋势:随着大数据和人工智能技术的飞速发展,对算法的需求不断升高。对于软件测试人员而言,掌握基本算法并不断更新新技能显得尤为重要。

常见问题解答(FAQ)

冒泡排序的时间复杂度是什么?

  • 冒泡排序的时间复杂度最坏情况下为O(n^2),空间复杂度为O(1)。

选择排序的效率高吗?

  • 选择排序的时间复杂度为O(n^2),其效率在一定范围内较低,但对于小型数据集表现尚可。

何时使用冒泡排序?

  • 当需处理的数据集较小,且对算法的简单性有所追求时,冒泡排序很合适。

选择排序适合什么场景?

  • 选择排序适合内存限制较大且对空间复杂度要求不高的场合。

送您一份软件测试学习资料大礼包

推荐阅读

软件测试学习笔记丨Pytest配置文件
测试开发实战 | Docker+Jmeter+InfluxDB+Grafana 搭建性能监控平台
技术分享 | app自动化测试(Android)--元素定位方式与隐式等待
软件测试学习笔记丨Mitmproxy使用
软件测试学习笔记丨Chrome开发者模式
软件测试学习笔记丨Docker 安装、管理、搭建服务
软件测试学习笔记丨Postman基础使用
人工智能 | 阿里通义千问大模型
软件测试学习笔记丨接口测试与接口协议
软件测试学习笔记丨Pytest的使用

推荐学习

【霍格沃兹测试开发】7天软件测试快速入门带你从零基础/转行/小白/就业/测试用例设计实战

【霍格沃兹测试开发】最新版!Web 自动化测试从入门到精通/ 电子商务产品实战/Selenium (上集)

【霍格沃兹测试开发】最新版!Web 自动化测试从入门到精通/ 电子商务产品实战/Selenium (下集)

【霍格沃兹测试开发】明星讲师精心打造最新Python 教程软件测试开发从业者必学(上集)

【霍格沃兹测试开发】明星讲师精心打造最新Python 教程软件测试开发从业者必学(下集)

【霍格沃兹测试开发】精品课合集/ 自动化测试/ 性能测试/ 精准测试/ 测试左移/ 测试右移/ 人工智能测试

【霍格沃兹测试开发】腾讯/ 百度/ 阿里/ 字节测试专家技术沙龙分享合集/ 精准化测试/ 流量回放/Diff

【霍格沃兹测试开发】Pytest 用例结构/ 编写规范 / 免费分享

【霍格沃兹测试开发】JMeter 实时性能监控平台/ 数据分析展示系统Grafana/Docker 安装

【霍格沃兹测试开发】接口自动化测试的场景有哪些?为什么要做接口自动化测试?如何一键生成测试报告?

【霍格沃兹测试开发】面试技巧指导/ 测试开发能力评级/1V1 模拟面试实战/ 冲刺年薪百万!

【霍格沃兹测试开发】腾讯软件测试能力评级标准/ 要评级表格的联系我

【霍格沃兹测试开发】Pytest 与Allure2 一键生成测试报告/ 测试用例断言/ 数据驱动/ 参数化

【霍格沃兹测试开发】App 功能测试实战快速入门/adb 常用命令/adb 压力测试

【霍格沃兹测试开发】阿里/ 百度/ 腾讯/ 滴滴/ 字节/ 一线大厂面试真题讲解,卷完拿高薪Offer !

【霍格沃兹测试开发】App自动化测试零基础快速入门/Appium/自动化用例录制/参数配置

【霍格沃兹测试开发】如何用Postman 做接口测试,从入门到实战/ 接口抓包(最新最全教程)

相关推荐
Felix_12154 小时前
2025 西电软工数据结构机考 Tip (By Felix)
算法
飞yu流星5 小时前
C++ 函数 模板
开发语言·c++·算法
没有名字的鬼5 小时前
C_字符数组存储汉字字符串及其索引
c语言·开发语言·数据结构
pursuit_csdn5 小时前
力扣 74. 搜索二维矩阵
算法·leetcode·矩阵
labuladuo5206 小时前
洛谷 P8703 [蓝桥杯 2019 国 B] 最优包含(dp)
算法·蓝桥杯·动态规划
Milk夜雨6 小时前
C语言冒泡排序教程简介
数据结构·算法·排序算法
委婉待续7 小时前
redis的学习(三)
数据结构·算法
一直学习永不止步7 小时前
LeetCode题练习与总结:随机翻转矩阵--519
java·数学·算法·leetcode·哈希表·水塘抽样·随机化
xiao--xin7 小时前
LeetCode100之组合总和(39)--Java
java·开发语言·算法·leetcode·回溯
测试杂货铺7 小时前
selenium遇见伪元素该如何处理?
自动化测试·软件测试·python·selenium·测试工具·职场和发展·测试用例