C++实现希尔排序(ShellSort)
作者:ChanJose 发布时间:2022-03-03 22:29:13
标签:C++,希尔排序
本文实例为大家分享了C++实现希尔排序的具体代码,供大家参考,具体内容如下
一、思路:
希尔排序:又称缩小增量排序,是一种改进的插入排序算法,是不稳定的。
设排序元素序列有n个元素,首先取一个整数gap<n作为间隔,将全部元素分为gap个子序列,所有距离为gap的元素放在同一个子序列中,在每一个子序列中分别施行直接插入排序。然后缩小间隔gap,重复上述的子序列和排序工作。
二、实现程序:
#include <iostream>
using namespace std;
const int maxSize = 20;
// 希尔排序:每次减小1/3,直到d=1;
// 因为前面增量比较大,间隔比较,减少比较的次数,已经将部分排好序,
// 后面虽然d越来越小,但是因为前面已经排好序,所以,后面插入需要比
// 较的次数减少。
template <class T>
void ShellSort(T arr[], const int left, const int right) {
int i, j, gap, temp; // gap为增量
gap = right - left + 1; // 增量的初始值
do{ // 直到增量值为1
gap = gap / 3 + 1; // 求下一增量值
for(i = left + gap; i <= right; i++) {
if(arr[i] < arr[i-gap]) {
temp = arr[i];
j = i - gap;
do {
arr[j+gap] = arr[j]; // 后移元素
j = j - gap; // 再比较前一元素
}while(j >= left && temp < arr[j]);
arr[j+gap] = temp; // 回填
}
} // for
}while(gap > 1);
} // ShellSort
int main(int argc, const char * argv[]) {
int i, n, arr[maxSize];
cout << "请输入要排序的数的个数:";
cin >> n;
cout << "请输入要排序的数:";
for(i = 0; i < n; i++)
cin >> arr[i];
cout << "排序前:" << endl;
for(i = 0; i < n; i++)
cout << arr[i] << " ";
cout << endl;
ShellSort(arr, 0, n-1);
cout << "排序后:" << endl;
for(i = 0; i < n; i++)
cout << arr[i] << " ";
cout << endl;
return 0;
}
测试结果:
来源:https://blog.csdn.net/chuanzhouxiao/article/details/89080393


猜你喜欢
- 在java数组中,查找数组元素是比较基础的操作了,arrays类的binarySearch就是专门实现指定元素的。同时它也属于我们常说的二分
- 前言 Android自带的组件比较丑陋(个人感觉),自己写组件比较复杂,而且必须
- 以前使用spring的使用要注入property要配置PropertyPlaceholder的bean对象。在springboot除&nbs
- 如何快速判断一个元素是不是在一个集合里?这个题目是我最近面试的时候常问的一个问题,这个问题不同人都有很多不同的回答。今天想介绍一个很少有人会
- 数据导出到Excel几乎是所有客户都会提出的一个需求。下面我就分享一下我的代码。首先需要引入的jar包:然后就是正式代码了。package
- 反阈值二值化反阈值二值化与阈值二值化互为逆操作。在OpenCV中该类的实现依赖于threshold() 函数。下面是该函数的声明:thres
- 本文实例讲述了C#直线的最小二乘法线性回归运算方法。分享给大家供大家参考。具体如下:1.Point结构在编写C#窗体应用程序时,因为引用了S
- 1. 继承1. 子类继承了父类,获得父类的全部Field和方法。子类Student类继承父类,将可以获得父类的全部Field和方法publi
- 本文实例为大家分享了WPF实现文字粒子闪烁动画的具体代码,供大家参考,具体内容如下实现效果如下:思路:首先根据显示文本创建文本路径Geome
- 最近自己写了个小爬虫,里面用到了多线程技术,忽然发现对此技术竟然有些陌生了,于是乎开始疯狂的去问度娘,在此记录下来,以便自己和各位小伙伴们学
- C/C++ 左移<<, 右移>>作用1. 左移 <<取两个数字,左移第一个操作数的位,第二个操作数决定要
- Android静默安装的方法,静默安装就是绕过安装程序时的提示窗口,直接在后台安装。注意:静默安装的前提是设备有ROOT权限。代码如下:/*
- package com.cjonline.foundation.authority.pojo;import java.util
- 扩展阅读c#基础系列1---深入理解 值类型和引用类型c#基础系列2---深入理解 String引言在上篇文章深入理解值类型和引用类型的时候
- 本文实例讲述了C#编程读取文档Doc、Docx及Pdf内容的方法。分享给大家供大家参考。具体分析如下:Doc文档:Microsoft Wor
- IDEA service层跳转实现类的快捷图标消失了,但别人IDEA同样的代码可以正常看到跳转图标。。(暗示:这只是你的IDEA 编译器的b
- 在项目中如果涉及到用Excel开发的报表模版来导出报表数据的话,一般都是在Excel报表中使用VBA做成宏来进行调用。即先使用Excel自带
- 在此附上超详细Windows 10卸载JDK1.8教程超详细Windows 10卸载JDK1.8教程JDK1.8即为JDK8,JDK8是目前
- 简单的IM聊天程序由于项目需要做一个基于XMPP协议的Android通讯软件。故开始研究XMPP。XMPP协议采用的是客户端-服务器架构,所
- 本文为大家分享了Spring Boot全局异常处理,供大家参考,具体内容如下1、后台处理异常a、引入thymeleaf依赖<!-- t