1759_C语言中冒泡排序的实现以及新编译环境测试

news2025/1/11 14:42:58

全部学习汇总: GreyZhang/c_basic: little bits of c. (github.com)

最近在重新学习C语言的数据结构,找了一份国外的电子书一点点看。刚刚学完双向链表,接下来的任务是搞定几个常用的排序。

冒泡排序还算是我比较熟悉的,工作之后遇到的排序功能我基本上都是首选这个算法进行排序功能的实现。

冒泡排序是把一个序列分为已经排序的和没有排序的两部分,左侧的数据作为排好序的部分,右侧的为未排序部分。从最左边的一个数据开始作为比较对象,依次遍历比较右边的数据。如果右边的数据比左边的小,那么两者交换位置。完成右边的便利比较之后,左侧的数据成为已经排好序的部分。接下来,进行第二个数据的排序。如此循环,直到处理完整个数据序列。

一个C语言的冒泡排序核心代码实现如下:

void BubbleSort(int *array,size_t array_size)

{

    int i = 0;

    int j = 0;

   

    for(i = 0; i < array_size; i++)

    {

        for(j = i + 1; j < array_size; j++)

        {

            if(array[i] > array[j])

            {

                array[i] = array[i] ^ array[j];

                array[j] = array[i] ^ array[j];

                array[i] = array[i] ^ array[j];

            }

        }

    }

}

void ArrayPrint(int *array,size_t array_size)

{

    int i = 0;

    for(i = 0; i < array_size; i++)

    {

        printf("%d,",array[i]);

    }

}

测试数据以及主函数中的测试调用主要代码如下:

#include "stdio.h"

#include "bubble_sort.h"

int test_array[12] = {1,3,5,7,2,5,9,5,21,55,1,0};

int main(void)

{

    printf("before sorted:\n");

    ArrayPrint(test_array,MY_CARD(test_array));

         BubbleSort(test_array,MY_CARD(test_array));

         printf("\nafter sorted:\n");

         ArrayPrint(test_array,MY_CARD(test_array));

    return 0;   

}

编译运行结果如下:

测试看来,编译环境正常,排序正确。

 

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Java数据结构和算法-----数组

1、Java数组介绍 在Java中&#xff0c;数组是用来存放同一种数据类型的集合&#xff0c;注意只能存放同一种数据类型(Object类型数组除外)。 ①、数组的声明 第一种方式&#xff1a; 1 数据类型 [] 数组名称 new 数据类型[数组长度]; 这里 [] 可以放在数组名称的前面&#…

Idea整合Maven安装及配置教程(图文详解)

目录 友情提醒第一章、Maven概述1.1&#xff09;Maven是什么1.2&#xff09;Maven进行构建&#xff08;build&#xff09;的主要环节 第二章、Maven的下载安装和配置2.1&#xff09;Maven的下载2.2&#xff09;Maven环境变量配置2.3&#xff09;Maven文件setting的配置 第三章、…

python+selenium自动化测试学习—手动搭建selenium环境

提示&#xff1a;文章写完后&#xff0c;目录可以自动生成&#xff0c;如何生成可参考右边的帮助文档 pythonselenium自动化测试学习—手动搭建selenium环境 一、简介二、安装selenium三、下载浏览器驱动四、搭建selenium环境 一、简介 selenium是一个免费开源的&#xff0c;仅…

FOC-滑膜控制器SMC/滑膜观测器SMO

目录 前面 滑膜速度控制器 控制器所处位置 理论设计 模型搭建 滑膜观测器 基本原理 反正切函数 锁相环 滑膜观测器模型&#xff08;反正切&#xff09; 滑膜观测器C代码实现 SMO.c SMO.h 前面 滑膜常见用处有两个&#xff1a; 1、作为滑膜控制器SMC&#xff0c;…

日本电子电器PSE认证METI备案、结构分析函报告详细解答

PSE认证是日本强制性安全认证&#xff0c;用以证明电子电气产品已通过日本电气和原料安全法 (DENAN Law) 或国际IEC标准的安全标准测试&#xff0c;457种产品进入日本市场必须通过PSE认证&#xff0c;其中&#xff0c;116种A类产品为特定电器和材料类&#xff0c;须获取认证并加…

机器学习中的Embeddings是什么

嵌入已经渗透到数据科学家的工具包中&#xff0c;并极大地改变了 NLP、计算机视觉和推荐系统的工作方式。然而&#xff0c;许多数据科学家发现它们过时且令人困惑。更多的人在不了解它们是什么的情况下盲目地使用它们。在本文中&#xff0c;我们将深入探讨嵌入是什么、它们如何…

【vue3】14-Vue全家桶-VueX状态管理

Vue全家桶 - VueX状态管理 认识应用状态管理VueX的状态管理 Vuex状态管理详解Vuex的基本使用单一状态树核心概念State组件获取状态setup中获取状态 核心概念Gettersgetters基本使用getters辅助函数 核心概念MutationsMutation基本使用mutation携带数据Mutation常量类型Mutation…

ModaHub魔搭社区:Zilliz Cloud 多组织与角色管理功能,让你的权限管理更简单!

目录 组织与角色功能简介 如何使用组织与角色功能&#xff1f; Zilliz Cloud 云服务是一套高效、高度可扩展的向量检索解决方案。近期&#xff0c;我们发布了 Zilliz Cloud 新版本&#xff0c;在 Zilliz Cloud 向量数据库中增添了许多新功能。其中&#xff0c;用户呼声最高的…

从零开始备战数学建模国赛之线性规划1.1

从零开始备战数学建模国赛之线性规划1.1 现在距离2023年的数学建模国赛还有不足三个月的时间&#xff0c;想与大家共同备战国赛。 这是我自己总结的一些代码和资料&#xff08;本文中的代码以及参考书籍等&#xff09;&#xff0c;放在github上供大家参考&#xff1a;https://…

流量控制 Sentinel

一、Sentinel(哨兵)简介 1、Sentinel的功能及特点 1.Sentinel的功能 Sentinel的支持 2.Sentinel的特点 Sentinel的特点 2、Sentinel的组成 核心库&#xff08;Java 客户端&#xff09;不依赖任何框架/库&#xff0c;能够运行于所有 Java 8 及以上的运行时环境&#xff0c;同…

HMAC算法详解

1.HMAC算法 1.1 HMAC算法简介 HMAC&#xff08;Hash-based Message Authentication Code&#xff0c;散列消息认证码&#xff09;是一种使用密码散列函数&#xff0c;同时结合一个加密密钥&#xff0c;通过特别计算方式之后产生的消息认证码&#xff08;MAC&#xff09;。它可…

Go语言使用中遇到的错误

Go语言使用中遇到的错误 1、go: go.mod file not found in current directory or any parent directory. 先运行这一行代码&#xff1a; go mod init name再运行你的 go get 命令就好了。 2、Failed to build the application: main.go:4:2: package generateproject/route…

C++之报错:is an inaccessible base of(一百四十五)

简介&#xff1a; CSDN博客专家&#xff0c;专注Android/Linux系统&#xff0c;分享多mic语音方案、音视频、编解码等技术&#xff0c;与大家一起成长&#xff01; 优质专栏&#xff1a;Audio工程师进阶系列【原创干货持续更新中……】&#x1f680; 人生格言&#xff1a; 人生…

物业管理变牛的好办法,新手零基础必备!

随着城市化进程的加速和商务发展的蓬勃&#xff0c;写字楼作为商业活动的核心场所&#xff0c;在现代都市生活中扮演着至关重要的角色。 随之而来的安全威胁和管理难题也日益凸显。因此&#xff0c;为了确保写字楼内部的安全与秩序&#xff0c;提高工作人员和访客的出入效率&am…

slab 内存池的设计与实现

目录 从一个简单的内存页开始聊 slab slab 的总体架构设计 slab 的组织架构 ​编辑 ​编辑 参考文献 伙伴系统内存分配原理的相关内容来看&#xff0c;伙伴系统管理物理内存的最小单位是物理内存页 page。也就是说&#xff0c;当我们向伙伴系统申请内存时&#xff0c;至少…

Windows:prometheus + grafana + wmi_exporter+ 主机信息监控页面 + 支持主机信息告警

1、PrometheusGrafana环境搭建 1.1、Prometheus 下载地址&#xff1a;Download | Prometheus 选择对应的系统的版本下载并解压压缩包&#xff0c;运行程序 本人在window系统上操作 双击 验证 浏览器输入http://localhost:9090/ 点击Staatus>Targets 出现以下即成功 1.…

Unifying Large Language Models and Knowledge Graphs: A Roadmap

5.2 LLM-augmented KG Completion 知识图谱补全(KGC)是指对给定知识图谱中缺失的事实进行推断的任务。与KGE类似,传统的KGC方法主要关注于KG的结构,而没有考虑广泛的文本信息。然而,最近llm的集成使KGC方法能够对文本进行编码或生成事实,以获得更好的KGC性能。这些方法根据…

【数据科学赛】2023大模型应用创新挑战赛 #¥10万 #百度

CompHub 主页增加了“近两周上新的奖金赛”&#xff0c;更加方便查找最新比赛&#xff0c;欢迎访问和反馈&#xff01; 以下内容摘自比赛主页&#xff08;点击文末阅读原文进入&#xff09; Part1赛题介绍 题目 2023大模型应用创新挑战赛 举办平台 Baidu AI Studio 主办方…

git介绍和使用

目录 一、git概述 1、简介 2、下载安装 二、git代码托管服务 1、常用的 Git 代码托管服务 2、使用码云代码托管服务 三、git常用命令 1、git全局设置 2、获取git仓库 3、工作区、暂存区、版本库 概念 4、Git工作区中文件的状态 5、本地仓库操作 6、远程仓库操作 …

Jetson Nano介绍

1. bo1公版介绍 Jetson NanoBO1公版的实物图如下图所示。其中1是TF卡接口&#xff0c;可以进行系统镜像烧写&#xff1b;2是40PIN GPIO扩展接口&#xff1b;3是用来传输数据或使用电源供电的Micro USB接口&#xff1b;4是千兆以太网口&#xff1b;5是USB3.0接口&#xff1b;6是…