当前位置: 首页 > news >正文

中山住房和建设局网站平面设计相关的网站有哪些

中山住房和建设局网站,平面设计相关的网站有哪些,紫砂壶网站开发与设计报告论文,珠海网站建设多少钱个人主页#xff1a;平行线也会相交 欢迎 点赞#x1f44d; 收藏✨ 留言✉ 加关注#x1f493;本文由 平行线也会相交 原创 收录于专栏【数据结构初阶#xff08;C实现#xff09;】 我们直到一般的排序都是通过关键字的比较和移动这两种操作来进行排序的。 而今天介绍的… 个人主页平行线也会相交 欢迎 点赞 收藏✨ 留言✉ 加关注本文由 平行线也会相交 原创 收录于专栏【数据结构初阶C实现】 我们直到一般的排序都是通过关键字的比较和移动这两种操作来进行排序的。 而今天介绍的基数排序并不是依靠关键字的比较和移动来进行数据元素的排序。 基数排序是一种借助多关键字的思想对单逻辑关键字进行排序方法。 本文目录 1️⃣样例演示2️⃣基数排序介绍3️⃣算法思想4️⃣代码示例5️⃣总结 1️⃣样例演示 基数排序的概念描述和思想比较难懂所以我们先来一个样例演示。然后再来细细品味基数排序的概念和思想。 我们对下面这个数组中的元素进行排序来进行演示 int arr[10] { 177 208 64 910 586 182 405 239 83 1 }我们按照最低位优先法发来进行排序可以看到数组中最高位为百位所以总共要进行三轮排序。 第一趟 第二趟 第三趟 可以看到每趟排序后回收数据时按照队列先进先出的思想来进行回收数据。 2️⃣基数排序介绍 基数排序Radix Sort是一种非比较排序算法它将待排序的元素按照位数从低位到高位从高位到低位也可以依次进行排序。本文按照从低位到高位为例进行演示。 3️⃣算法思想 基数排序的算法思想可以概括为以下几个步骤 1.确定待排序元素的最高位数即最大位数首先需要确定待排序元素中的最大值并计算出它的位数这决定了排序过程需要进行多少轮。 2.按照最低有效位进行一次稳定的排序从最低位开始将待排序元素按照最低有效位的值进行稳定排序可以使用计数排序或桶排序等算法实现。排序后元素相对于最低位来说是有序的。 3.按照次低有效位进行稳定排序将上一轮排序得到的有序序列按照次低有效位的值进行稳定排序。这样在当前位和低位均已有序的前提下排序后整个序列相对于当前位来说是有序的。 4.重复执行步骤3直到按照最高位进行排序依次对每一位进行稳定排序直到按照最高位排序完成。最终得到的序列即为完全有序的结果。 4️⃣代码示例 #includeiostream #includequeue using namespace std;#define RADIX 10 #define K 3 //排序3轮queueint Q[RADIX];int getkey(int value, int k) {int key 0;while (k 0){key value % 10;value / 10;k--;}return key; }void distribute(int arr[], int left, int right,int k) {for (int i left; i right; i){int key getkey(arr[i], k);Q[key].push(arr[i]);} }void collect(int arr[]) {int k 0;for (int i 0; i RADIX; i){while (!Q[i].empty()){arr[k] Q[i].front();Q[i].pop();}} } void ridixsort(int arr[], int left, int right) {for (int i 0; i K; i){//分发数据distribute(arr, left, right, i);//回收数据collect(arr);}}int main() {int arr[] { 177 ,208 ,64, 910 ,586, 182, 405, 239, 83, 1 };int n sizeof(arr) / sizeof(arr[0]);for (int i 0; i n; i){printf(%d , arr[i]);}printf(\n);ridixsort(arr, 0, n);for (int i 0; i n; i){printf(%d , arr[i]);}printf(\n);return 0; }运行结果如下 5️⃣总结 关于基数排序的几大要点总结一下 1.基数排序是一种非比较排序算法通过将待排序的元素按照位数进行拆分并依次对每一位进行稳定的排序从而达到整体有序的效果。 2.基数排序的稳定性非常重要即在每一轮排序时保证相同位上值相等的元素的相对顺序不变。 3.确定待排序元素的最高位数这决定了排序过程需要进行多少轮。 4.对每一位依次进行稳定排序可以使用计数排序、桶排序等方法来实现。 5.基数排序的时间复杂度为O(dn)其中d为待排序元素的最大位数n为元素的个数。空间复杂度为O(n k)其中k为计数排序或桶排序中桶的个数。 6.基数排序适用于待排序元素位数相对较小且范围较小的情况但如果待排序元素的位数差异较大或者位数较多时性能可能受到影响。 7.基数排序是稳定的排序算法可以应用于对整数、字符串等类型的数据进行排序。
http://www.pierceye.com/news/363105/

相关文章:

  • 旅游网站建设计划书wordpress弱密码
  • 网站建设项目报价网站开发与设计结课论文
  • 公司做网站企业做网站需注意什么
  • 已经注册了域名 怎么做网站自己注册一家公司需要多少钱
  • 沈阳做网站的电话网站 扩展
  • 健身俱乐部网站开发文档重庆 企业网站建设
  • 深圳航空公司官方网站招聘做网站广告公司
  • .php的网站是怎么做的最美情侣免费视频
  • v9网站模板学做西点的网站
  • 网站查询空间商工厂生产erp管理系统
  • 365房产南京网站响应式wordpress主题
  • 上海网站建设 app开发佛山黄页企业名录
  • 网站优化文档天津建设厅网站
  • 网站建设自适应网站电商网站运营规划
  • 做网站如何报价泰州建设局网站质监站
  • 做家具网站电影网站做流量吗
  • 免费1级做看网站制作单页网站要网址
  • 网站返回首页怎么做的好看自贡网站优化
  • 自己的网站如何做推广wordpress积分与奖励
  • 产品包装设计网站网站建设 中企动力宜昌
  • 英语营销型网站建设北京pk10网站开发
  • 交换链接适合哪些网站东莞小程序开发制作
  • 医院网站建设网站阿里巴巴网站是用什么技术做的
  • 潍坊 餐饮网站建设淘宝seo优化
  • 樟木头镇网站建设公司WordPress企业响应式主题
  • 怎么给网站做备份呢怎么去建设微信网站
  • 成都各公司网站中小企业网站建设 论文
  • 广告网站建设实训报告做电商从哪里入手
  • 建电子商务网站需要多少钱做网站的简称
  • 制定网站推广方案网络营销网站分析