题目描述
将一正整数序列{K1,K2,…,K9}重新排列成一个新的序列。新序列中,比K1小的数都在K1的前面(左面),比K1大的数都在K1的后面(右面)。
输入格式
输入有多行,第一行为N表示行数,每行9个整数.
输出格式
输出N行,按要求进行排序的结果.
样例输入
2
6 8 9 1 2 5 4 7 3
3 5 8 9 1 2 6 4 7
样例输出
3 4 5 2 1 6 8 9 7
2 1 3 5 8 9 6 4 7
这里写一种不需要排序的简单做法。利用遍历的思想。时间复杂度是O(n)
实在没有思路其实可以先排序再输出,也是符合题目要求的,就是自己测试的时候一直不通过,不知道是什么原因。
#include<iostream>
#include<vector>
#include<algorithm>
using namespace std;
int main(){
int n;
cin>>n;
while(n--){
int a[9]={0};
for(int i=0;i<9;i++){
cin>>a[i];
}
int x=a[0];
for(int i=8;i>0;i--){
if(a[i]<x)cout<<a[i]<<' ';
}
cout<<x<<' ';
for(int i=1;i<9;i++){
if(a[i]>x){
cout<<a[i]<<' ';
}
}cout<<endl;
}
system("pause");
return 0;
}