算法学习 - STL的p排序函数(sort)使用

排序函数sort()

这个函数是STL自带的,功能很强大~ 这里教下使用方法。

sort()有三个参数,第一个是排序的起始位置,第二个是排序的结束位置,第三个是排序的判断函数。函数原型为:

sort(<#_RandomAccessIterator __first#>, <#_RandomAccessIterator
__last#>, <#_Compare __comp#>)

这个就是原型了~

使用方法

首先假设我们有一个vector<int> vec;向量容器,存放了很多无序正数,那么我们就开始用sort给这些整数排序。首先其实位置是:vec.begin()结束位置是:vec.end(),比较函数可以不写,默认是升序。也可以手写。

代码实现

直接看代码实现会很简单~

//
//  main.cpp
//  hdu_1040
//
//  Created by Alps on 15/1/3.
//  Copyright (c) 2015年 chen. All rights reserved.
//
//http://acm.hdu.edu.cn/showproblem.php?pid=1040

#include <iostream>
#include <vector>
using namespace std;

bool sortRule(int a, int b){
    return a < b;
}

int main(int argc, const char * argv[]) {
    int n;
    scanf("%d",&n);
    int num;
    int a = 0;
    for (int i = 0; i < n; i++) {
        scanf("%d",&num);
        vector<int> list;
        while (num--) {
            scanf("%d",&a);
            list.push_back(a);
        }
        sort(list.begin(), list.end(), sortRule);
        vector<int>::iterator iter;
        for (iter = list.begin(); iter != list.end(); iter++) {
            printf("%d",*iter);
            if (iter == list.end()-1) {
                printf("\n");
            }else{
                printf(" ");
            }
        }
    }
    return 0;
}

这就是个实现代码了~测试例子请看:

http://acm.hdu.edu.cn/showproblem.php?pid=1040 给的输入格式。

时间: 2024-10-26 15:17:39

算法学习 - STL的p排序函数(sort)使用的相关文章

C++ 排序函数 sort(),qsort()的使用方法

想起来自己天天排序排序,冒泡啊,二分查找啊,结果在STL中就自带了排序函数sort,qsort,总算把自己解脱了~ 所以自己总结了一下,首先看sort函数见下表: 函数名 功能描写叙述 sort 对给定区间全部元素进行排序 stable_sort 对给定区间全部元素进行稳定排序 partial_sort 对给定区间全部元素部分排序 partial_sort_copy 对给定区间复制并排序 nth_element 找出给定区间的某个位置相应的元素 is_sorted 推断一个区间是否已经排好序 p

排序函数sort用法简介

排序算法有很多,冒泡排序,选择排序,堆排序,快速排序,归并排序,基数排序-- 其中平均复杂度O(nlogn)的排序算法或者在某方面有特殊优势的算法在ACM中才有实际使用价值,所以上述提到的前2种大家以后就不要用了.其他排序算法大家会慢慢接触,本文主要介绍使用最多的排序函数 sort.大家可能会遇到qsort,qsort比较复杂,逐渐淡出ACMer的视线,所以不用管它. sort函数是C++标准库函数,需要包含头文件 #include <algorithm> 并声明命名空间 using name

C++ 排序函数 sort(),qsort()的含义与用法 ,字符串string 的逆序排序等

上学时我们很多学了很多种排序算法,不过在c++stl中也封装了sort等函数,头文件是#include <algorithm> 函数名 功能描述 sort 对给定区间所有元素进行排序 stable_sort 对给定区间所有元素进行稳定排序 partial_sort 对给定区间所有元素部分排序 partial_sort_copy 对给定区间复制并排序 nth_element 找出给定区间的某个位置对应的元素 is_sorted 判断一个区间是否已经排好序 partition 使得符合某个条件的元

C++ 排序函数 sort(),qsort()的用法

转自:http://blog.csdn.net/zzzmmmkkk/article/details/4266888/ 所以自己总结了一下,首先看sort函数见下表: 函数名 功能描述 sort 对给定区间所有元素进行排序 stable_sort 对给定区间所有元素进行稳定排序 partial_sort 对给定区间所有元素部分排序 partial_sort_copy 对给定区间复制并排序 nth_element 找出给定区间的某个位置对应的元素 is_sorted 判断一个区间是否已经排好序 pa

PHP排序函数sort底层实现分析

线性表(即线性数据结构,如数组和链表)的常规排序算法,包括冒泡.插入.选择.归并和快排,其中综合性能最好的就是快排(快速排序),所以快排在工程实践中也有大量的应用,比如很多编程语言都提供了排序函数,而这些排序函数基本都是基于快速排序实现的,比如 PHP 的数组排序函数 sort 就是如此. 今天我们将以此函数的底层实现为例,为大家展示如何基于快速排序来实现 PHP 的 sort 函数(准确的说,是综合运用了插入排序和快速排序). PHP 数组排序函数 sort 底层实现分析 首先我们来给大家介绍

Python3:排序函数sort() 和 sorted() 之介绍

今天来讲一下Python中的排序函数.Python中有2个内建的排序函数,分别为sort() 和 sorted() 下面介绍分别介绍一下2个函数: 1.有一个列表 :a=[1,4,5,88,0,7],想要实现排序功能,可以使用sort() 和 sorted(): a.sort() #默认升序排列 print(a) 输出:[0, 1, 4, 5, 7, 88] a.sort(reverse=True) #reverse=True,降序排列.默认FALSE:升序: print(a) 输出:[88,

(C++)STL排序函数sort和qsort的用法与区别

主要内容: 1.qsort的用法 2.sort的用法 3.qsort和sort的区别 qsort的用法: 原 型: void qsort(void *base, int nelem, int width, int (*fcmp)(const void *,const void *)); 功 能: 使用快速排序例程进行排序 参 数: 1 待排序数组首地址 2 数组中待排序元素数量 3 各元素的占用空间大小 4 指向函数的指针,用于确定排序的顺序 说 明:qsort函数是ANSI C标准中提供的,其

算法学习——STL和基本数据结构

第一次接触算法,只是照着自己的方法学习的,总结写的可能不是会很好,但我会努力改进. #STL容器包括顺序式容器和关联式容器. 顺序式容器: ·vector:动态数组,从末尾能快速插入与删除,直接访问任何元素. ·list:双链表,从任何地方快速插入与删除. ·deque:双向队列,从前面或后面快速插入与删除,直接访问任何元素. ·queue:队列,先进先出 ·priority_queue:优先队列,最高优先级元素总是第一个出列. ·stack:栈,先进后出. 关联式容器: ·set:集合,快速查

PHP中的排序函数sort、asort、rsort、krsort、ksort区别分析

在php中自带了大量了数组排序函数,下面我们一一来介绍一下关于php数组排序的用法吧. sort() 函数用于对数组单元从低到高进行排序. rsort() 函数用于对数组单元从高到低进行排序. asort() 函数用于对数组单元从低到高进行排序并保持索引关系. arsort() 函数用于对数组单元从高到低进行排序并保持索引关系. ksort() 函数用于对数组单元按照键名从低到高进行排序. krsort() 函数用于对数组单元按照键名从高到低进行排序. sort() PHP sort() 函数用