算法-排序-基数排序(对任意整数排序)

基数排序

时间复杂度:Θ(d(n+k))
d:元素的位数,k元素中每位数的取值区间大小
非原址排序
1⃣️特点该排序只能每次为基数为1位数进行排序

void radix_sort(int *array,int length,int digits){vector<KeyValuePair> temp_array(length);for (int i = 0; i < length; ++i) {temp_array[i].value = array[i];}for (int i = 0; i < digits; ++i) {for (int j = 0; j < length; ++j){temp_array[j].key = (temp_array[j].value / (int) pow(10,i)) % 10;}counting_sort_by_key(temp_array);}for (int i = 0; i < length; ++i) {array[i] = temp_array[i].value;}
}

辅助类:KeyValuePair
链接地址
辅助排序 counting_sort_by_key
链接地址

2⃣️以多位数 r 为基础进行排序(r<=b,b为总位数),不在是一位一位的排序
时间复杂度Θ((b/r)(n+2^r))。
通常情况下,若b = O(lgn),取r≈lgn,则基数排序的运行时间为Θ(n)。

void radix_sort(int *array,int length,int total_digits,int single_digit){vector<KeyValuePair> temp_array(length);for (int i = 0; i < length; ++i) {temp_array[i].value = array[i];}for (int i = 0 ; i < total_digits; i += single_digit) {for (int j = 0; j < length; ++j){temp_array[j].key = (temp_array[j].value / (int) pow(10,i)) % ((int) pow(10,single_digit));}counting_sort_by_key(temp_array,-(int) pow(10,single_digit),(int) pow(10,single_digit));}for (int i = 0; i < length; ++i) {array[i] = temp_array[i].value;}
}

3⃣️基数排序的诡异版本
基数排序的不在以10进制分割,而是以任意大于1的自然数(代码中的range)分割。
参数 range 取值大于n时一定成功,小于n时不一定成功。有兴趣的同学可以共同探讨下。
时间复杂度Θ(log(range,max{ |array中元素|})(n+2range))

void radix_sort_by_range(int *array,int length,int range)
{vector<KeyValuePair> temp_array(length);for (int i = 0; i < length; ++i) {temp_array[i].value = array[i];}int i = 0;bool interrupt = true;while (true){interrupt = true;for (int j = 0; j < length; ++j){temp_array[j].key = (temp_array[j].value / (int) pow(range,i)) % range;interrupt = interrupt && !temp_array[j].key;}if(interrupt)break;i++;counting_sort_by_key(temp_array,-range,range);}for (int i = 0; i < length; ++i) {array[i] = temp_array[i].value;}
}

vector容器版本

void radix_sort(vector<int> &array,int digits)
{vector<KeyValuePair> temp_array(array.size());for (int i = 0; i < array.size(); ++i) {temp_array[i].value = array[i];}for (int i = 0; i < digits; ++i) {for (int j = 0; j < array.size(); ++j){temp_array[j].key = (temp_array[j].value / (int) pow(10,i)) % 10;}counting_sort_by_key(temp_array);}for (int i = 0; i < array.size(); ++i) {array[i] = temp_array[i].value;}
}

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

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

相关文章

.NET 5.0预览版6发布:支持Windows ARM64设备

2020年6月25日&#xff0c;微软dotnet团队在博客宣布了第六个 .NET 5.0 的预览版&#xff1a;https://devblogs.microsoft.com/dotnet/announcing-net-5-0-preview-6/&#xff0c;在改进性能的同时增加了一些新的功能。ASP.NET Core和 EF Core也将于今日发布了。注意&#xff1…

利用真值表法求取主析取范式以及主合取范式的实现(C++)

代码如下: #include <iostream> #include <stack> #include <string> #include <vector> using namespace std; const int N 300; stack<char> s; stack<char> v; int seq; bool vis[N]; bool flag[N]; void dfs(int n); vector<int&…

基于 Blazor 开发五子棋小游戏

今天是农历五月初五&#xff0c;端午节。在此&#xff0c;祝大家端午安康&#xff01;端午节是中华民族古老的传统节日之一。端午也称端五&#xff0c;端阳。此外&#xff0c;端午节还有许多别称&#xff0c;如&#xff1a;午日节、重五节、五月节、浴兰节、女儿节、天中节、地…

工具类—KeyValuePair

工具类KeyValuePair .h文件 #ifndef C11LEARN_KEYVALUEPAIR_H #define C11LEARN_KEYVALUEPAIR_Hclass KeyValuePair { public:int key;int value; public:KeyValuePair();KeyValuePair(int key,int value); };#endif //C11LEARN_KEYVALUEPAIR_H.cpp文件 #include "KeyV…

汇编cmp比较指令详解

刚刚看到了cmp指令&#xff0c;一开始有点晕。后来上网找了些资料&#xff0c;终于看明白了&#xff0c;为了方便初学者&#xff0c;我就简单写下我的思路吧。高手绕过&#xff0c;谢谢&#xff01; cmp(compare)指令进行比较两个操作数的大小例:cmp oprd1,oprd2为第一个操作减…

如何在ASP.NET Core中使用SignalR构建与Angular通信的实时通信应用程序

图片假设我们要创建一个监视Web应用程序&#xff0c;该应用程序为用户提供了一个能够显示一系列信息的仪表板&#xff0c;这些信息会随着时间的推移而更新。第一种方法是在定义的时间间隔&#xff08;轮询&#xff09;定期调用API 以更新仪表板上的数据。无论如何&#xff0c;还…

算法-排序-桶排序

桶排序 桶排序期望的运行时间是Θ(n) 局限&#xff1a;输入数组要在[0,1)之间&#xff08;下面有更通用的版本3⃣️&#xff09; 1⃣️内置排序没有用插入排序而是c自带的sort&#xff0c;要用插入排序可保证算法稳定性。 void bucket_sort(float *array,int length){vector&…

LED计数电路,5输入按键编码器,7段数码管显示驱动集成为LED计数测试电路

LED计数电路: 5输入按键编码器: 7段数码管显示驱动真值表: 集成:

越卖越涨?腾讯股票3月后大涨45%,超越“阿里”成中国第一,市值相当于14.3个百度!...

01 腾讯股价大涨据股市最新消息&#xff1a;腾讯股价已连续3个交易日上涨, 其中6月22日腾讯股价重返470港元关口&#xff0c;公司市值突破4.5万亿港元&#xff0c;折合4.0万亿人民币&#xff1b;而6月23日上午腾讯股价再度大涨4.05%&#xff0c;刷出493.8港元的新高&#xf…

4位无符号比较器设计

4位比较器原理&#xff1a; 4位比较 a3a2a1a0 : b3b2b1b0&#xff0c;比较顺序从高位到低位&#xff0c;当高位大、小关系确定时则无需看低位&#xff0c;当高位相等时再看相邻低位的关系。 注意&#xff1a;对于三个比较结果&#xff0c;已知其中任意两个&#xff0c;可以用…

算法导论水壶问题(第三版第八章思考题8-4)

算法导论水壶问题 &#xff08;第三版第八章思考题8-4&#xff09; 本算法只适用于解题&#xff0c;不通用。 期望的时间复杂度O&#xff08;nlgn&#xff09; Kettle.h文件 #ifndef C11LEARN_KETTLE_H #define C11LEARN_KETTLE_H#include <iostream> #include <vec…

关于技术文章“标题党”一事我想说两句

阅读本文大概需要 1.8 分钟。前天发表的一篇文章&#xff0c;标题是&#xff1a;“面试官&#xff1a;你刚说你喜欢研究新技术&#xff0c;那么请说说你对 Blazor 的了解”。确实&#xff0c;这篇文章有标题党的味道&#xff0c;如果因此给部分童鞋带来不适&#xff0c;我在这先…

算法-排序-k排序(算法导论第三版第八章思考题8-5)

算法-排序-k排序 算法导论第三版第八章思考题8-5 时间复杂度Θ(nlg(n/k))。 利用最小堆完成&#xff0c;把元素分成k个堆&#xff0c;每个堆大小⌈n/k⌉。 利用堆作为子排序稳定&#xff0c;也可以采用其他排序作为子排序&#xff0c;子排序的算法时间复杂度保证在Θ(klgk)就行…

使用 nuget server 的 API 来实现搜索安装 nuget 包

使用 nuget server 的 API 来实现搜索安装 nuget 包Intronuget 现在几乎是 dotnet 开发不可缺少的一部分了&#xff0c;还没有用过 nuget 的就有点落后时代了&#xff0c;还不快用起来nuget 是 dotnet 里的包管理机制&#xff0c;类似于前端的 npm &#xff0c;php 的 composer…

找出第二小元素(算法导论第三版9.1-1题)

找出第二小元素&#xff08;算法导论第三版9.1-1题&#xff09; 时间复杂度Θ(n) 比较次数n⌈lgn⌉−2次 思路&#xff1a;将元素每次分成2部分&#xff0c;第一部分和第二部分元素成对比较。最终获得最小的元素&#xff0c;记录那些和最小元素比较后的失败的元素&#xff0c;…

Kubernetes:通过自动化节省IT预算的4种方法

导语大多数CIO和IT领导者都熟悉反复执行的任务“事半功倍”。在许多组织中&#xff0c;这都是现实&#xff0c;在各种其他因素&#xff08;例如宏观经济状况&#xff09;的影响下&#xff0c;这种趋势往往会起伏不定。正文有时&#xff0c;“用更少的钱做更多的事”可能会更准确…