代码拉取完成,页面将自动刷新
/*!
* @file shell_sort.h
* @author CyberDash计算机考研, cyberdash@163.com(抖音id:cyberdash_yuan)
* @brief 希尔排序
* @version 0.2.1
* @date 2021-09-19
*/
/*!
* @brief **间隔区间插入排序**
* @tparam TElement 数组元素类型模板参数
* @param elements 数组
* @param gap 间隔
* @param length 数组长度
* @note
* 间隔区间插入排序
* -------------
* -------------
*
* -------------
*/
template <typename TElement>
void GapedInsertionSort(TElement* elements, int gap, int length) {
for (int i = gap; i < length; i++) {
if (elements[i] >= elements[i - gap]) {
continue;
}
TElement cur = elements[i];
int j;
for (j = i - gap; j >= 0 && cur < elements[j]; j -= gap) {
elements[j + gap] = elements[j];
}
elements[j + gap] = cur;
}
}
/*!
* @brief **希尔排序**
* @tparam TElement
* @param elements 数组
* @param gaps 间隔数组
* @param length 数组长度
* @param gaps_count 间隔数组长度
* @note
* 希尔排序
* -------
* -------
*
* -------
*/
template <typename TElement>
void ShellSort(TElement* elements, int* gaps, int length, int gaps_count) {
for (int i = 0; i < gaps_count; i++) {
GapedInsertionSort(elements, gaps[i], length);
}
}
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。