每天一个小算法(Shell Sort3)
希尔算法自己编了一个,循环很多,很不美观,不过运行正确:
c语言实现:
#include <stdio.h>
#include <stdlib.h>
#define LEN 20 int main()
{
int d,i,j,k;
int arr[]={20,19,16,17,11,12,13,18,14,15,10,9,8,7,6,5,4,3,2,1};
int key; for(d=LEN/2;d>0;d--)
for(i=0;i<d;i++)
for(j=i+d;j<LEN;j=j+d)
{
k=j;
key=arr[j];
while(k>0 && arr[k-d]>key)
{
arr[k]=arr[k-d];
k=k-d;
}
arr[k]=key;
} for(i=0;i<LEN;i++)
printf("%d\n",arr[i]);
}
运行结果:
明天任务:
好好思考希尔排序的实现;想一想如何优化比较好。
每天一个小算法(Shell Sort3)的更多相关文章
- 每天一个小算法(Shell sort5)
		
希尔排序的关键在于步长的选取. 希尔排序的复杂度比较复杂,主要跟步长的选择有关,大概是 O(n logn^2),一般认为就是介于 O(n^2) 和 O(n logn) 之间.最好步长比较复杂,一般第一 ...
 - 每天一个小算法(Shell Sort1)
		
希尔排序是1959 年由D.L.Shell 提出来的,相对直接排序有较大的改进.希尔排序又叫缩小增量排序 基本思想: 先将整个待排序的记录序列分割成为若干子序列分别进行直接插入排序,待整个序列中的记录 ...
 - 每天一个小算法(insertion sort3)
		
今天多看看插入排序的理论部分. 先贴几个概念吧: 1.伪代码(英语:pseudocode),又称为虚拟代码,是高层次描述算法的一种方法.它不是一种现实存在的编程语言(已经出现了类似伪代码的语言,参见N ...
 - 每天一个小算法(Shell Sort2)
		
希尔排序: 伪代码: input: an array a of length n with array elements numbered 0 to n − 1 inc ← round(n/2) wh ...
 - 每天一个小算法(4)----在O(1)时间删除指定结点
		
O(1)时间内删除结点的思路只能是复制该结点下一个结点的数据,然后删除该结点的下一个结点,来等效删除此结点. 需要注意的地方是删除头结点和尾结点的处理. #include <stdio.h> ...
 - python3 自己写的一个小算法(比对中文文本相似度)
		
函数使用说明: 函数的三个参数分别是“匹配语句”,“匹配语料”,“相关度”: 匹配语句,和匹配预料中的语句匹配的语句,必须为字符串: 匹配语料,被匹配语句来匹配的语句列表,必须为列表: 相关度,函数只 ...
 - 感冒了~ vs中py和vb实现一个小算法
		
1+1*2+1*2*3+--+1*2*3*n 下面是窗体,就一个按钮和编辑框. 中途还遇到了编码问题,但是感冒太难受,加上明天还要上课.就睡了~ 晚安世界.
 - Python数学运算的一个小算法(求一元二次方程的实根)
		
请定义一个函数quadratic(a, b, c),接收3个参数,返回一元二次方程:ax² + bx + c = 0的两个解. #!/usr/bin/env python # -*- coding: ...
 - 每天一个小算法(Heapsort)
		
#include "stdio.h" #include "stdlib.h" #define Num 10 Heap(int arr[],int i,int n ...
 
随机推荐
- 802.11 wireless 五
			
802.11 wireless 5CSMA/CA,采用倒计时的方法,退避的时间(当年时间+duration 为发送时间,每一个帧会有一个duration,这个位叫做duration[n.持续]) PS ...
 - 【Lua】Lua中__index与元表(转)
			
转载于:http://blog.csdn.net/xocoder/article/details/9028347 Lua的表本质其实是个类似HashMap的东西,其元素是很多的Key-Value对,如 ...
 - Leetcode#87 Scramble String
			
原题地址 两个字符串满足什么条件才称得上是scramble的呢? 如果s1和s2的长度等于1,显然只有s1=s2时才是scramble关系. 如果s1和s2的长度大于1,那么就对s1和s2进行分割,划 ...
 - GS连接事件
			
GS网络连接事件 //网络事件 //这个事件是在libevent里面的收到的事件就是在那个listen里面,就是客户端打开,服务器收到通知 link_stat stat = (link_stat)rP ...
 - mysql导出导入某张表
			
一般表数据少的话都用图形界面了,看着比较方便. 如果表中数据比较多,用图形界面极容易卡死,这个时候就要用到命令行了. 用命令行导出导入大量数据还是比较快的,方法如下: 导出库db1中的表table1: ...
 - ios中webservice报文的拼接
			
1.报文头需要密码验证的 - (void)sendAsynWebServiceRequest:(NSString *)nameSpace method:(NSString *)method reque ...
 - HTTP persistent connection
			
http://en.wikipedia.org/wiki/HTTP_persistent_connection
 - C# 对委托的BeginInvoke,EndInvoke 及Control 的BeginInvoke,EndInvoke 的理解
			
using System; using System.Collections.Generic; using System.ComponentModel; using System.Data; usin ...
 - vi/vim使用指北 ---- Moving Around in a Hurry
			
上一篇文章中,简单列出了一些基本的Vim操作,也列出了很多的光标移动命令,本章主要是有哪些命令可以更快的移动光标. vim的编辑操作,用得最多就是移动光标,对于很少行的文件来说,基本的命令就够用了,但 ...
 - 使用 Swagger UI 与 Swashbuckle 创建 RESTful Web API 帮助文件
			
作者:Sreekanth Mothukuru 2016年2月18日 本文旨在介绍如何使用常用的 Swagger 和 Swashbuckle 框架创建描述 Restful API 的交互界面,并为 AP ...