问题 B: 【排序】常用排序法
时间限制: 1 Sec 内存限制: 64 MB
提交: 69 解决: 41
[提交] [状态] [讨论版] [命题人:]
题目描述
为了快速地把修罗王和邪狼从混乱的队伍中找出来,典狱长准备对排队的囚犯进行从小到大的按编号排序,但是他不知道用哪一种排序方法最合适,因此他准备请教前来协助的高级魔法师张琪曼和楚继光。
输入
共两行,第一行为一个数N(N≤100000),即排队的总人数,第二行为N个数,即每个人的编号,每个编号均不超过int类型的最大值。
输出
输出排好序的数列,每个数以空格间隙。行尾有空格
样例输入
10 2 1 76 11 4 765 32 56 3 23
样例输出
1 2 3 4 11 23 32 56 76 765
分析:排序。。。
#include <iostream> #include <string> #include <cstdio> #include <cmath> #include <cstring> #include <algorithm> #include <vector> #include <queue> #include <deque> #include <map> #define range(i,a,b) for(int i=a;i<=b;++i) #define LL long long #define rerange(i,a,b) for(int i=a;i>=b;--i) #define fill(arr,tmp) memset(arr,tmp,sizeof(arr)) using namespace std; int n; vector<int>num; void init(){ cin>>n; num.resize(n+1); range(i,1,n)cin>>num[i]; sort(num.begin()+1,num.end()); } void solve(){ vector<int>::iterator iter; for(iter=num.begin()+1;iter!=num.end();++iter)cout<<*iter<<(iter==num.end()-1?‘\n‘:‘ ‘); } int main() { init(); solve(); return 0; }
原文地址:https://www.cnblogs.com/Rhythm-/p/9348136.html
时间: 2024-10-13 08:45:58