基础排序算法

冒泡排序

冒泡排序(Bubble Sort)一种交换排序,它的基本思想是:两两比较相邻记录的关键字,如果反序则交换,直到没有反序的记录为止。

以下代码是改进的冒泡算法,在排序好了之后可以直接跳出循环,避免有没必要的循环出现呢。

/* 对顺序表 L 改进冒泡算法 */
void BubbleSort2(SqList *L)
{int i, j;Status flag = TRUE;    /* flag 用来作为标记 */for (i = 1; i < L->length && flag; i++)  /* 若 flag 为 true 则退出循环 */{flag = FALSE;           /* 初始为 false */for (j = L->length - 1; j >= i; j--){if (L->r[j] > L->r[j + 1]){swap(L, j, j + 1); /* 交换 L->r[j]与 L->r[j + 1]的值 */flag = TRUE;    /* 如果有数据交换,则 flag 为 true */}}}
}

简单排序

简单选择排序法(Simple Selection Sort)就是通过 n - i 次关键字间的比较,从 n - i + 1 个记录中选出关键字最小的记录,并和第 i(1≤i≤n)个记录交换之。

/* 对顺序表 L 作简单选择排序 */
void SelectSort(SqList *L)
{int i, j, min;for (i = 1; i < L->length; i++){min = i;                       /* 将当前下标定义为最小值下标 */for (j = i + 1; j <= L->length; j++) /* 循环之后的数据 */{if (L->r[min] > L->r[j])    /* 如果有小于当前最小值的关键字 */min = j;                 /* 将此关键字的下标赋值给 min */}if (i!= min)                    /* 若 min 不等于 i,说明找到最小值,交换 */swap(L, i, min);            /* 交换 L->r[i]与 L->r[min]的值 */}
}

直接排序

直接插入排序(Straight Insertion Sort)的基本操作是将一个记录插入到已经排好序的有序表中,从而得到一个新的、记录数增1的有序表。

/* 对顺序表 L 作直接插入排序 */
void InsertSort(SqList *L)
{int i, j;for (i = 2; i <= L->length; i++){if (L->r[i] < L->r[i - 1])  /* 需将 L->r[i]插入有序子表 */{L->r[0] = L->r[i];      /* 设置哨兵 */for (j = i - 1; L->r[j] > L->r[0]; j--)L->r[j + 1] = L->r[j];  /* 记录后移 */L->r[j + 1] = L->r[0];      /* 插入到正确位置 */}}
}

希尔排序

希尔排序是对直接排序算法的优化,在面对基本有序的数据和较少的数据时,直接排序算法是比较高效的,希尔排序就是将一组数据先进行一些操作使其达到基本有序状态,最后再进行一次直接排序。

/* 对顺序表 L 作希尔排序 */
void ShellSort(SqList *L)
{int i, j;int increment = L->length;do{increment = increment / 3 + 1;  /* 增量序列 */for (i = increment + 1; i <= L->length; i++){if (L->r[i] < L->r[i - increment]){/* 需将 L->r[i]插入有序增量子表 */L->r[0] = L->r[i];    /* 暂存在 L->r[0] */for (j = i - increment; j > 0 && L->r[0] < L->r[j]; j -= increment)L->r[j + increment] = L->r[j]; /* 记录后移,查找插入位置 */L->r[j + increment] = L->r[0]; /* 插入 */}}} while (increment > 1);
}

堆排序

堆是具有下列性质的完全二叉树:每个结点的值都大于或等于其左右孩子结点的值,称为大顶堆;或者每个结点的值都小于或等于其左右孩子结点的值,称为小顶堆。

堆排序(Heap Sort)就是利用堆(假设利用大顶堆)进行排序的方法。它的基本思想是,将待排序的序列构造成一个大顶堆。此时,整个序列的最大值就是堆顶的根结点。将它移走(其实就是将其与堆数组的末尾元素交换,此时末尾元素就是最大值),然后将剩余的 n - 1 个序列重新构造成一个堆,这样就会得到 n 个元素中的次小值。如此反复执行,便能得到一个有序序列了。

/* 对顺序表 L 进行堆排序 */
void HeapSort(SqList *L)
{int i;for (i = L->length / 2; i > 0; i--)  /* 把 L 中的 r 构建成一个大顶堆 */HeapAdjust(L, i, L->length);for (i = L->length; i > 1; i--){swap(L, 1, i); /* 将堆顶记录和当前未经排序子序列的最后一个记录交换 */HeapAdjust(L, 1, i - 1); /* 将 L->r[1..i - 1]重新调整为大顶堆 */}
}

归并排序

归并排序(Merging Sort)就是利用归并的思想实现的排序方法。它的原理是假设初始序列含有 n 个记录,则可以看成是 n 个有序的子序列,每个子序列的长度为 1,然后两两归并,得到很多个个长度为 2 或 1 的有序子序列;再两两归并,……,如此重复,直至得到一个长度为 n 的有序序列为止,这种排序方法称为 2 -路归并排序。

/* 将 SR[s..t]归并排序为 TR1[s..t] */
void MSort(int SR[], int TR1[], int s, int t)
{int m;int TR2[MAXSIZE + 1];if (s == t)TR1[s] = SR[s];else{m = (s + t) / 2; /* 将 SR[s..t]平分为 SR[s..m]和 SR[m + 1..t] */MSort(SR, TR2, s, m); /* 递归将 SR[s..m]归并为有序的 TR2[s..m] */MSort(SR, TR2, m + 1, t); /* 递归将 SR[m + 1..t]归并为有序 TR2[m + 1..t] */Merge(TR2, TR1, s, m, t); /* 归并到 TR1[s..t] */}
}

利用迭代实现非递归的归并排序

/* 对顺序表 L 作归并非递归排序 */
void MergeSort(SqList *L)
{int *TR = (int *)malloc(L->length * sizeof(int)); /* 申请额外空间 */int k = 1;while (k < L->length){MergePass(L->r, TR, k, L->length);k = 2 * k;                   /* 子序列长度加倍 */MergePass(TR, L->r, k, L->length);k = 2 * k;                   /* 子序列长度加倍 */}
}

快速排序

快速排序(Quick Sort)的基本思想是:通过一趟排序将待排记录分割成独立的两部分,其中一部分记录的关键字均比另一部分记录的关键字小,则可分别对这两部分继续进行排序,以达到整个序列有序的目的。

/* 对顺序表 L 中的子序列 L->r[low..high]作快速排序 */
void QSort(SqList *L, int low, int high)
{int pivot;if (low < high){pivot = Partition(L, low, high); /* 将 L->r[low..high]一分为二, *//* 算出枢轴值 pivot */QSort(L, low, pivot - 1);        /* 对低子表递归排序 */QSort(L, pivot + 1, high);       /* 对高子表递归排序 */}
}

算法进阶指南例题(解题主要思路不在如何实现排序)

比较简单的一个排序题,但是因为数据点相差很大,所以要用一下离散化,就是把无限空间中有限的个体映射到有限的空间中去,以此提高算法的时空效率。 通俗的说,离散化是在不改变数据相对大小的条件下,对数据进行相应的缩小。

#include<bits/stdc++.h>
using namespace std;
const int N=200005;
unordered_map<int,int> m1;//统计用映射
int n,m,a[N],b[N],c[N],ans=-1;//ans 记录答案下标
int main(){cin>>n;for(int i=0;i<n;i++) cin>>a[i],m1[a[i]]++;//统计珂学家 cin>>m;for(int i=0;i<m;i++) cin>>b[i];for(int i=0;i<m;i++) cin>>c[i];ans=0;for(int i=0;i<m;i++){if(m1[b[i]]>m1[b[ans]]) ans=i;else if(m1[b[i]]==m1[b[ans]]&&m1[c[i]]>m1[c[ans]]) ans=i;}cout<<ans+1;//因为是下标,所以要加一return 0;
}

只能说为啥我没早做这题,昨天的测试题有一个跟这个逻辑几乎是一样的,今天早上才把它写出来。当仓库往右移动一个单位,仓库左边的商店距离会集体+1,右边的商店集体-1。所以很容易看出,商店建在最中间是距离之和最小的时候。所以我只要将商店按距离排好序,找到最中间的商店即可,若商店为双数,则在仓库可建在最中间的两个商店之间的任意位置。然后求和即可。

#include<bits/stdc++.h>
using namespace std;
const int maxn = 1e5 + 10;
int n, ans, a[maxn];
int main() {cin >> n;for (int i = 1; i <= n; i++) cin >> a[i];sort(a + 1, a + n + 1);for (int i = 1; i <= n / 2; i++)ans += (a[n - i + 1] - a[i]);cout << ans;return 0;
}

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

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

相关文章

什么是神经网络?

0 前言 神经网络是一种人工智能方法&#xff0c;用于教计算机以受人脑启发的方式处理数据。这是一种机器学习过程&#xff0c;称为深度学习&#xff0c;它使用类似于人脑的分层结构中的互连节点或神经元。它可以创建自适应系统&#xff0c;计算机使用该系统来从错误中进行学习…

MySQL 主从复制原理及其工作过程

一、MySQL主从复制原理 MySQL 主从复制是一种将数据从一个 MySQL 数据库服务器&#xff08;主服务器&#xff0c;Master&#xff09;复制到一个或多个 MySQL 数据库服务器&#xff08;从服务器&#xff0c;Slave&#xff09;的技术。以下简述其原理&#xff0c;主要包含三个核…

Ext系列文件系统 -- 磁盘结构,磁盘分区,inode,ext文件系统,软硬链接

目录 1.理解硬盘 1.1 磁盘、服务器、机柜、机房 1.2 磁盘物理结构 1.3 磁盘的存储结构 1.4 磁盘的逻辑结构 1.4.1 理解逻辑结构 1.4.2 真实过程 1.5 CHS地址和LBA地址的相互转换 2.引入文件系统 2.1 “块”概念 2.2 “分区”概念 2.3 “inode”概念 3.ext2文件系…

C# 背景 透明 抗锯齿 (效果完美)

主要是通过 P/Invoke 技术调用 Windows API 函数 gdi32.dll/user32.dll&#xff0c;同时定义了一些结构体来配合这些 API 函数的使用&#xff0c;常用于处理图形绘制、窗口显示等操作。 运行查看效果 局部放大&#xff0c;抗锯齿效果很不错,尾巴毛毛清晰可见。 using System; u…

Elasticsearch 混合搜索 - Hybrid Search

作者&#xff1a;来自 Elastic Valentin Crettaz 了解混合搜索、Elasticsearch 支持的混合搜索查询类型以及如何制作它们。 本文是三篇系列文章中的最后一篇&#xff0c;深入探讨了向量搜索&#xff08;又称语义搜索&#xff09;的复杂性以及它在 Elasticsearch 中的实现方式。…

【分布式理论12】事务协调者高可用:分布式选举算法

文章目录 一、分布式系统中事务协调的问题二、分布式选举算法1. Bully算法2. Raft算法3. ZAB算法 三、小结与比较 一、分布式系统中事务协调的问题 在分布式系统中&#xff0c;常常有多个节点&#xff08;应用&#xff09;共同处理不同的事务和资源。前文 【分布式理论9】分布式…

Zabbix 7.2实操指南:基于OpenEuler系统安装Zabbix 7.2

原文出处&#xff1a;乐维社区 部署环境 openEuler 22.03 LTS PHP 8.0 Apache Mysql 8.0 MySQL数据库 6.0 以上版本需要安装mysql8.0以上版本的数据库&#xff08;以mysql为例子&#xff09;。 欧拉系统自带 mysql8.0 的源&#xff0c;无需要安装额外的源。 安装mysql …

什么是DeFi (去中心化金融)

DeFi (去中心化金融) 概述 &#x1f4b0; 1. DeFi 基础概念 1.1 什么是 DeFi&#xff1f; DeFi 是建立在区块链上的金融服务生态系统&#xff0c;它&#xff1a; 无需中心化中介开放且透明无需许可即可参与代码即法律 1.2 DeFi 的优势 开放性&#xff1a;任何人都可以参与…

python-leetcode 39.二叉树的直径

题目&#xff1a; 给定一棵二叉树的根节点&#xff0c;返回该树的直径。 二叉树的直径是指中间任意两个节点之间最长路径的长度。这条路径可能经过也可能不经过根节点root 两节点之间路径的长度由他们之间的边数表示 方法一&#xff1a;深度优先搜索 一条路径的长度为该路…

python爬虫系列课程2:如何下载Xpath Helper

python爬虫系列课程2:如何下载Xpath Helper 一、访问极简插件官网二、点击搜索按钮三、输入xpath并点击搜索四、点击推荐下载五、将下载下来的文件解压缩六、打开扩展程序界面七、将xpath.crx文件拖入扩展程序界面一、访问极简插件官网 极简插件官网地址:https://chrome.zzz…

C++17 中的 std::to_chars 和 std::from_chars:高效且安全的字符串转换工具

文章目录 1. 传统转换方法的局限性2. std::to_chars&#xff1a;数值到字符串的高效转换函数原型&#xff1a;返回值&#xff1a;示例代码&#xff1a;输出&#xff1a; 3. std::from_chars&#xff1a;字符串到数值的高效解析函数原型&#xff1a;返回值&#xff1a;示例代码&…

初尝git自结命令大全与需要理解的地方记录

常用命令 git init–初始化工作区touch 文件全称–在工作区创建文档rm 文件全称 --删除文档notepad 文件全称–在工作区打开文档cat 文件全称–在显示框显示文档的东西git status --显示工作区的文件冲突的文件 &#xff08;git add 文件全称或者.&#xff09; —将工作区文件…

Python——生成AIGC图像

文章目录 一、背景介绍 二、效果图展示 三、完整代码 四、分步解释 五、实用建议 1&#xff09;提示词技巧 2&#xff09;性能优化 3&#xff09;常见问题处理 4&#xff09;扩展功能建议 六、注意事项 1. 硬件要求 2. 法律合规 3. 模型安全 一、背景介绍 AIGC&a…

MyBatis框架七:缓存

精心整理了最新的面试资料&#xff0c;有需要的可以自行获取 点击前往百度网盘获取 点击前往夸克网盘获取 MyBatis缓存介绍 正如大多数持久层框架一样&#xff0c;MyBatis 同样提供了一级缓存和二级缓存的支持 1、一级缓存: 基于PerpetualCache 的 HashMap本地缓存&#xf…

【Unity动画】导入动画资源到项目中,Animator播放角色动画片段,角色会跟随着动画播放移动。

导入动画资源到项目中&#xff0c;Animator播放角色动画片段,角色会跟随着动画播放移动&#xff0c;但我只想要角色在原地播放动画。比如&#xff1a;播放一个角色Run动画&#xff0c;希望角色在原地奔跑&#xff0c;而不是产生了移动距离。 问题排查&#xff1a; 1.是否勾选…

WLAN无线2.4G/5G频段划分和可用信道

互联网各领域资料分享专区(不定期更新)&#xff1a; Sheet

2025年archlinux tigervnc分辨率设置不生效的问题

在此之前我知道的修改分辨率的方法&#xff0c;有两种&#xff1a; 1. 参数geometry实现 在ubuntu中配置vnc,可以参考&#xff1a; 《ubuntu server 20.04安装vnc远程桌面xfce4》 https://blog.csdn.net/lxyoucan/article/details/121672487 设置vnc的分辨率非常简单 vncse…

MySQL数据库(6)—— 表的增删查改

目录 一&#xff0c;表的CRUD 二&#xff0c;Create新增 2.1 SQL介绍 2.2 按行和列插入 2.3 插入否则更新 2.4 插入替换 三&#xff0c;Retrieve查找 3.1 SQL介绍 3.2 按列查询 3.3 查询字段为表达式 3.4 结果去重 3.5 where关键字 3.6 对结果排序 3.7 分页显示 …

【实战】用飞书多维表格+AI DeepSeeker做股票量价分析

用2万元起步资金&#xff0c;进行A股实战模拟。&#xff08;量化分析无法知晓 消息面的事宜&#xff0c;是一个不足&#xff0c;但是可以代替 哪些一般水平的 股票分析师&#xff09; https://zk4wn8rhv2.feishu.cn/base/OABmbEBa4a4zgOsw5JlcrfIPnzh?tabletblMK2bDhPW5Am9b&a…

深度学习之迁移学习resnet18模型及调用模型预测

迁移学习resnet18模型及调用模型预测 目录 迁移学习resnet18模型及调用模型预测1 迁移学习1.1 概念1.2 主要思想1.3 优点1.4 迁移学习的步骤 2 模型迁移和调整2.1 ResNet18模型2.2 新数据2.3 冻结参数2.4 微调层2.5 新增层2.6 数据预处理 3 代码测试3.1 微调模型代码测试及保存…