专业网站建设品牌,十四年专业建站经验,服务6000+客户--广州京杭网络
免费热线:400-683-0016      微信咨询  |  联系我们

c排序—sort_java

当前位置:网站建设 > 技术支持
资料来源:网络整理       时间:2023/3/5 22:27:02       共计:3594 浏览

c排序—sort?

一、sort()是c++、java里对数组的元素进行排序的方法,包含于头文件algorithm。

返回值:

对数组的引用。请注意,数组在原数组上进行排序,不生成副本。

说明:

如果调用该方法时没有使用参数,将按字母顺序对数组中的元素进行排序,说得更精确点,是按照字符编码的顺序进行排序。要实现这一点,首先应把数组的元素都转换成字符串(如有必要),以便进行比较。

如果想按照其他标准进行排序,就需要提供比较函数,该函数要比较两个值,然后返回一个用于说明这两个值的相对顺序的数字。比较函数应该具有两个参数a和b,其返回值如下:

若a小于b,在排序后的数组中a应该出现在b之前,则返回一个小于0的值。

若a等于b,则返回0。(此时不排序)

若a大于b,则返回一个大于0的值。

程序示例:

在本例中,我们将创建一个数组,并按字母顺序进行排序:

<scripttype="text/javascript">vararr=newArray(6)arr[0]="George"arr[1]="John"arr[2]="Thomas"arr[3]="James"arr[4]="Adrew"arr[5]="Martin"document.write(arr+"<br/>")document.write(arr.sort())</script>

输出:

George,John,Thomas,James,Adrew,MartinAdrew,George,James,John,Martin,Thomas

二、partial_sort是C++STL中的函数

函数原型有:

partial_sort(beg,mid,end)

partial_sort(beg,mid,end,comp)

函数作用:

对mid-beg个元素进行排序,也就是说,如果mid-beg等于42,则该函数将有序次序中的最小值元素放在序列中

的前42个位置。partial_sort完成之后,从beg到mid(但不包括mid)范围内的元素时有序的,已排序范围内没有

元素大于mid之后的元素。未排序元素之间的次序是未指定的。

程序示例:

#include<vector>

#include<iterator>

#include<iostream>

#include<algorithm>

#include<functional>

#include<cstdlib>

#include<time.h>

usingnamespacestd;

intrand_int()

{

returnrand()%100;

}

voidprint(vector<int>&v,constchar*s)

{

cout<<s<<endl;

copy(v.begin(),v.end(),ostream_iterator<int>(cout,""));

cout<<endl;

}

boolcmp(int&a,int&b)

{

if(a>b)

returntrue;

returnfalse;

}

classcompare{

public:

booloperator()(constint&a,constint&b)

{

if(a<b)

returntrue;

returnfalse;

}

};

intmain()

{

srand(time(NULL));

vector<int>v;

generate_n(back_inserter(v),10,rand_int);

print(v,"产生10个随机数");

partial_sort(v.begin(),v.begin()+4,v.end());

print(v,"局部递增排序");

partial_sort(v.begin(),v.begin()+4,v.end(),cmp);

print(v,"局部递减排序");

partial_sort(v.begin(),v.begin()+4,v.end(),compare());

print(v,"局部递增排序");

return0;

}

版权说明:
本网站凡注明“广州京杭 原创”的皆为本站原创文章,如需转载请注明出处!
本网转载皆注明出处,遵循行业规范,如发现作品内容版权或其它问题的,请与我们联系处理!
欢迎扫描右侧微信二维码与我们联系。
·上一条:学java时数据库一定要学好吗_java | ·下一条:eclipse有没有快捷输入方法_java

Copyright © 广州京杭网络科技有限公司 2005-2025 版权所有    粤ICP备16019765号 

广州京杭网络科技有限公司 版权所有