Delphi常用排序
1.冒泡排序
|
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
|
procedure BubbleSort(var x:array of integer);var i,j,intTmp:integer;begin for i:=0 to high(x) do begin for j:=0 to high(x)-1 do begin if x[j]>x[j+1] then begin intTmp:=x[j]; x[j]:=x[j+1]; x[j+1]:=intTmp; end; end; end;end; |
2.选择排序
|
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
|
procedure SelectSort(var x:array of integer);var i,j,k,intTmp:integer;begin for i:=0 to high(x)-1 do begin intTmp:=x[i]; k:=i; for j:=i+1 to high(x) do begin if intTmp>x[j] then begin k:=j; intTmp:=x[k]; end; end; if k<>i then begin x[k]:=x[i]; x[i]:=intTmp; end; end;end; |
3.插入排序
|
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
|
procedure InsertSort(var x:array of integer);var i,j,intTmp:integer;begin for i:=1 to high(x) do begin for j:=i downto 1 do begin if x[j-1]>x[j] then begin intTmp:=x[j-1]; x[j-1]:=x[j]; x[j]:=intTmp; end; end; end;end; |
4.希尔排序
|
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
|
procedure ShellSort(var x:array of integer);var h,i,j,intTmp:integer;begin h:=high(x) div 2; while h>0 do begin for i:=h to high(x) do begin j:=i; while (j>=h) and (x[j-h]>x[j]) do begin intTmp:=x[j-h]; x[j-h]:=x[j]; x[j]:=intTmp; j:=j-h; end; end; h:=h div 2; end;end; |
5.快速排序
|
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
|
procedure QuickSort(var x:array of integer; L,R:integer);var i,j,intTmp:integer;begin if L<R then begin i:=L; j:=R; intTmp:=x[i]; while i<j do begin while (i<j) and (x[j]>=intTmp) do begin j:=j-1; end; if i<j then x[i]:=x[j]; while (i<j) and (x[i]<=intTmp) do begin i:=i+1; end; if i<j then x[j]:=x[i]; end; x[i]:=intTmp; QuickSort(x,L,i-1); QuickSort(x,i+1,R); end;end; |
6.归并排序
|
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
|
procedure Merge(var x,y:array of integer; L,M,R:integer);var i,j:integer;begin i:=L; j:=M+1; while (L<=M) and (j<=R) do begin if x[L]> x[j] then begin y[i]:=x[j]; j:=j+1; end else begin y[i]:=x[L]; L:=L+1; end; i:=i+1; end; while L<=M do begin y[i]:=x[L]; i:=i+1; L:=L+1; end; while j<=R do begin y[i]:=x[j]; i:=i+1; j:=j+1; end;end;procedure MergeSort(var x, y:TArrInt);var intLength,intLen,intLen_m,i:integer; tmp:TArrInt;begin intLength:=high(x)+1; intLen:=1; while intLen<intLength do begin intLen_m:=intLen; intLen:=intLen*2; i:=0; while i+intLen<intLength do begin Merge(x,y,i,i+intLen_m-1,i+intLen-1); i:=i+intLen; end; if i+intLen_m<intLength then begin Merge(x,y,i,i+intLen_m-1,intLength-1); end; tmp:=x; x:=y; y:=tmp; end;end; |
7.堆排序
|
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
|
procedure HeapAdjust(var x:array of integer; i,intLen:integer);var intTmp,intChild:integer;begin intTmp:=x[i]; intChild:=2*i+1; while intChild<intLen do begin if (intChild+1<intLen) and (x[intChild]<x[intChild+1]) then begin intChild:=intChild+1; end; if x[i]<x[intChild] then begin x[i]:=x[intChild]; i:=intChild; intChild:=2*i+1; end else begin break; end; x[i]:=intTmp; end;end;procedure BuildHeap(var x:array of integer);var i:integer;begin for i:=high(x) div 2 downto 0 do begin HeapAdjust(x,i,High(x)+1); end;end;procedure HeapSort(var x:array of integer);var i,intTmp:integer;begin BuildHeap(x); for i:=high(x) downto 0 do begin intTmp:=x[i]; x[i]:=x[0]; x[0]:=intTmp; HeapAdjust(x,0,i); end;end; |
Delphi常用排序的更多相关文章
- Delphi常用字符串函数
Delphi常用字符串函数 一.字符转换函数1.ord(input[i])返回字符表达式 input 左端起第 I 字符的ASCII 码值.2.CHAR()将ASCII 码转换为字符.如果没有输入 ...
- Java常用排序算法+程序员必须掌握的8大排序算法+二分法查找法
Java 常用排序算法/程序员必须掌握的 8大排序算法 本文由网络资料整理转载而来,如有问题,欢迎指正! 分类: 1)插入排序(直接插入排序.希尔排序) 2)交换排序(冒泡排序.快速排序) 3)选择排 ...
- Delphi常用系统函数总结
Delphi常用系统函数总结 字符串处理函数 Unit System 函数原型 function Concat(s1 [, s2,..., sn]: string): string; 说明 与 S : ...
- 转载部长一篇大作:常用排序算法之JavaScript实现
转载部长一篇大作:常用排序算法之JavaScript实现 注:本文是转载实验室同门王部长的大作,找实习找工作在即,本文颇有用处!原文出处:http://www.cnblogs.com/ywang172 ...
- Java 常用排序算法/程序员必须掌握的 8大排序算法
Java 常用排序算法/程序员必须掌握的 8大排序算法 分类: 1)插入排序(直接插入排序.希尔排序) 2)交换排序(冒泡排序.快速排序) 3)选择排序(直接选择排序.堆排序) 4)归并排序 5)分配 ...
- (转载)delphi 常用函数(数学)
delphi 常用函数(数学) Delphi中怎么将实数取整? floor 和 ceil 是 math unit 里的函数,使用前要先 Uses Math.trunc 和 round 是 system ...
- 常用排序算法的python实现和性能分析
常用排序算法的python实现和性能分析 一年一度的换工作高峰又到了,HR大概每天都塞几份简历过来,基本上一天安排两个面试的话,当天就只能加班干活了.趁着面试别人的机会,自己也把一些基础算法和一些面试 ...
- Delphi 常用函数(数学函数)round、trunc、ceil和floor
源:Delphi 常用函数(数学函数)round.trunc.ceil和floor Delphi 常用函数(数学) Delphi中怎么将实数取整? floor 和 ceil 是 math unit 里 ...
- Delphi 常用API 函数
Delphi 常用API 函数 AdjustWindowRect 给定一种窗口样式,计算获得目标客户区矩形所需的窗口大小 AnyPopup 判断屏幕上是否存在任何弹出式窗口 ArrangeIconic ...
随机推荐
- JS获取URL的参数
function request(paras) { var url = location.href; , url.length).split("&"); var paraO ...
- Mysql内存表的用处
文章出自:http://blog.csdn.net/hitzhang/article/details/5994639 个人最欣赏mysql的地方就是他存储引擎的多样性和可扩展性,这样mysql也能拥有 ...
- [功能帮助类] 最新的Functions 类 (转载)
代码 using System; using System.Collections.Generic; using System.Text; using System.Security.Cryptogr ...
- listview中button抢占焦点问题
解决办法Item xml 根节点添加 android:descendantFocusability="blocksDescendants" Button 设置 android:fo ...
- HTML中的API
在程序语言里面就使用API这个行为来讲,可拆解为两个操作:取得API接口和运行API功能 例如:书本具有传授知识的功能,这里就好比一个API,学生拿出某个课本学习,就相当于取得API,学习通过课本学习 ...
- CentOS PHP-5.4.8 编译安装之初体验
1. 下载5.4.8 版本 [root@Test data] wget http://museum.php.net/php5/php-5.4.8.tar.gz 2. 解压 [root@Test php ...
- 文件上传利器SWFUpload使用指南
这里就不再介绍什么是SWFUpload啦,简单为大家写一个简单关于SWFUpload的Demo. 1.把SWFUpload 相关的文件引用进来 2.创建upload.aspx页面(页面名称可自定义), ...
- AIX filesystemcache引发的Oracle事故
链接地址: http://www.jydba.net/aix-filesystemcache%e5%bc%95%e5%8f%91%e7%9a%84oracle%e4%ba%8b%e6%95%85/ A ...
- oracle 非空闲等待事件排查
想必大家都知道Oracle的等待时间分为两种,一种我们称之为“空闲等待事件”,另外一种称之为“非空闲等待事件”.“空闲等待事件”——作为DBA可以不用过分的关注这类等待事件.“非空闲等待事件”——当D ...
- Action<>和Func<>区别
Action<>和Func<>其实都是委托的[代理]简写形式. 简单的委托写法: //普通的委托 public delegate void myDelegate(string ...