快速排序的不同语言不同方法实现的…
2017-08-11 23:29
471 查看
GO
quick_sort(a) (x=a.pop) ? quick_sort(a.select { |i| i <= x}) + [x] + quick_sort(a.select { |i| i > x }) : []
end
超简短实现: q_sort([])-> [];
q_sort([H|R])->
q_sort([X||X<-R,X<-R,X>=H]).
q_sort n=case n of []->[]
(x:xs)->q_sort [a|a<-xs,a<=x]++[x]++q_sort
[a|a<-xs,a>x]
#include
using namespace
std;
void Qsort(int a[], int low,
int high)
{
if(low >= high)
{
return;
}
int first = low;
int last = high;
int key = a[first];
while(first < last)
{
while(first < last && a[last] >=
key)
{
--last;
}
a[first] =
a[last];
while(first < last && a[first] <=
key)
{
++first;
}
a[last] =
a[first];
}
a[first] = key;
Qsort(a, low, first-1);
Qsort(a, first+1, high);}int main(){
int a[] = {57, 68, 59, 52, 72, 28, 96, 33,
24};
Qsort(a, 0, sizeof(a) / sizeof(a[0]) -
1);
for(int i = 0; i < sizeof(a) / sizeof(a[0]);
i++)
{
cout
<< a[i] << "";
}
return 0;
// 第一种写法
func quickSort(values []
int
, left, right
int
) {
temp := values[left]
p := left
i, j := left, right
for
i <= j {
for
j >= p && values[j] >= temp {
j--
}
if
j >= p {
values[p] = values[j]
p = j
}
if
values[i] <= temp && i <= p {
i++
}
if
i <= p {
values[p] = values[i]
p = i
}
}
values[p] = temp
if
p-left > 1 {
quickSort(values, left, p-1)
}
if
right-p > 1 {
quickSort(values, p+1, right)
}
}
func QuickSort(values []
int
) {
if
len(values) <= 1 {
return
}
quickSort(values, 0, len(values)-1)
}
// 第二种写法
func Quick2Sort(values []
int
) {
if
len(values) <= 1 {
return
}
mid, i := values[0], 1
head, tail := 0, len(values)-1
for
head < tail {
fmt.Println(values)
if
values[i] > mid {
values[i], values[tail] = values[tail], values[i]
tail--
}
else
{
values[i], values[head] = values[head], values[i]
head++
i++
}
}
values[head] = mid
Quick2Sort(values[:head])
Quick2Sort(values[head+1:])
}Rubydef
quick_sort(a) (x=a.pop) ? quick_sort(a.select { |i| i <= x}) + [x] + quick_sort(a.select { |i| i > x }) : []
end
Erlang语言
超简短实现: q_sort([])-> [];q_sort([H|R])->
q_sort([X||X<-R,X<-R,X>=H]).
Haskell语言
q_sort n=case n of []->[](x:xs)->q_sort [a|a<-xs,a<=x]++[x]++q_sort
[a|a<-xs,a>x]
C++语言
#includeusing namespace
std;
void Qsort(int a[], int low,
int high)
{
if(low >= high)
{
return;
}
int first = low;
int last = high;
int key = a[first];
while(first < last)
{
while(first < last && a[last] >=
key)
{
--last;
}
a[first] =
a[last];
while(first < last && a[first] <=
key)
{
++first;
}
a[last] =
a[first];
}
a[first] = key;
Qsort(a, low, first-1);
Qsort(a, first+1, high);}int main(){
int a[] = {57, 68, 59, 52, 72, 28, 96, 33,
24};
Qsort(a, 0, sizeof(a) / sizeof(a[0]) -
1);
for(int i = 0; i < sizeof(a) / sizeof(a[0]);
i++)
{
cout
<< a[i] << "";
}
return 0;
相关文章推荐
- 快速排序的不同语言不同方法实现的…
- 快速排序的不同语言不同方法实现的…
- 快速排序基于不同枢纽的实现方法
- 快速排序的三种不同的实现方式。
- 快速排序模板方法,只实现了int比较的仿函数
- 快速排序方法Java实现与分析
- 【快速排序】QuickSort(三种实现方法)c++描述
- 深入浅出Dll(介绍函数导出、类导出、钓子dll、不同语言混合编程方法、插件等的实现方法)
- 汇编语言实现快速冒泡排序
- 算法导论 - 快速排序的 C 语言实现
- 深入浅出Dll( 函数导出、类导出、钓子dll、不同语言混合编程方法、插件等的实现方法)
- 快速实现Magento多语言的设置和产品数据的多语言方法
- 重写compareTo方法,按不同方式实现排序,小程序
- 快速排序三种实现方法
- 排序都有哪几种方法?请列举。用JAVA实现一个快速排序。
- 深入浅出Dll(介绍函数导出、类导出、钓子dll、不同语言混合编程方法、插件等的实现方法) 选择自 iceezone 的 Blog
- 主流数据库之间对SQL:2003标准的不同实现方法比较(第二部分 结果集排序)
- 快速排序-几种不同的划分方法
- 快速排序Java语言实现
- 深入浅出Dll( 函数导出、类导出、钓子dll、不同语言混合编程方法、插件等的实现方法)