排序——C++函数调用
2015-10-03 14:01
267 查看
C++提供了qsort函数对数据进行快读排序,也提供了sort函数对vector和list进行排序,比较函数和函数类型的参数是排序函数的关键。
#include<iostream>
#include<cstdlib>
#include<algorithm>
#include<vector>
#include<list>
#include<iterator>
using namespace std;
int QsCmp(const void *a, const void *b)
{
return *(int *)a-*(int *)b;
}
int SCmp(int a, int b)
{
return a > b;
}
int main()
{
vector<int> m;
list<int> l;
list<int>::iterator it;
int a;
for (int i = 0; i < 8; i++)
{
cin >> a;
m.push_back(a);
l.push_back(a);
}
/*
快速排序函数调用,第一个参数为指针首地址,第二个参数为排序数组大小,第三个参数为类型所占的字节数,最后一个为比较函数
*/
qsort(&m[0],8,sizeof(int),QsCmp);
for (int i = 0; i < 8; i++)
cout << m[i] << endl;
/*
向量排序
*/
sort(m.begin(),m.end(), SCmp);
for (int i = 0; i < 8; i++)
cout << m[i] << endl;
/*
list排序
*/
l.sort(SCmp);
for (it = l.begin(); it!=l.end(); it++)
cout << *it << endl;
system("pause");
return 0;
}
#include<iostream>
#include<cstdlib>
#include<algorithm>
#include<vector>
#include<list>
#include<iterator>
using namespace std;
int QsCmp(const void *a, const void *b)
{
return *(int *)a-*(int *)b;
}
int SCmp(int a, int b)
{
return a > b;
}
int main()
{
vector<int> m;
list<int> l;
list<int>::iterator it;
int a;
for (int i = 0; i < 8; i++)
{
cin >> a;
m.push_back(a);
l.push_back(a);
}
/*
快速排序函数调用,第一个参数为指针首地址,第二个参数为排序数组大小,第三个参数为类型所占的字节数,最后一个为比较函数
*/
qsort(&m[0],8,sizeof(int),QsCmp);
for (int i = 0; i < 8; i++)
cout << m[i] << endl;
/*
向量排序
*/
sort(m.begin(),m.end(), SCmp);
for (int i = 0; i < 8; i++)
cout << m[i] << endl;
/*
list排序
*/
l.sort(SCmp);
for (it = l.begin(); it!=l.end(); it++)
cout << *it << endl;
system("pause");
return 0;
}
相关文章推荐
- 文件遍历排序函数
- C#选择排序法实例分析
- C#插入法排序算法实例分析
- C#实现Datatable排序的方法
- SQLSERVER的排序问题结果不是想要的
- Windows Powershell排序和分组管道结果
- C#通过IComparable实现ListT.sort()排序
- C#选择法排序实例分析
- SQL学习笔记四 聚合函数、排序方法
- C#对list列表进行随机排序的方法
- 一根网线内的8根线哪4根是传输数据的,哪四根是防干扰的
- C#折半插入排序算法实现方法
- SQL进行排序、分组、统计的10个新技巧分享
- C++实现位图排序实例
- 基于C++实现的各种内部排序算法汇总
- C++线性时间的排序算法分析
- SQL行号排序和分页(SQL查询中插入行号 自定义分页的另类实现)
- PHP下对数组进行排序的函数
- PHP数组排序之sort、asort与ksort用法实例
- php通过asort()给关联数组按照值排序的方法