sdut oj 2109 找女朋友

sdut oj 2109 找女朋友
啦啦啦 小白第一次写博客 写了一个简单的快排和一个直接用set集排序 可能有些地方不对哈,欢迎各位big-old前来指点~

添加链接描述
快排~

#include <iostream>
int a[1000005],n;
using namespace std;
void quicksort(int left,int right){
    int temp=a[left];
    int i=left,j=right;
    if(i>j) return;
    while(i!=j){
        while(a[j]>=temp&&i<j) j--;
        while(a[i]<=temp&&i<j) i++;
        if(i<j){
            int t=a[j];
            a[j]=a[i];
            a[i]=t;
}
a[left]=a[i];
a[i]=temp;

quicksort(left,i-1);
quicksort(i+1,right);
}
}
int main()
{
cin>>n;
for(int i=0;i<n;i++){
    cin>>a[i];
}
quicksort(0,n-1);

for(int i=n-1;i>=0;i++){
    if(i==n-1){
cout<<a[i]<<endl;
break;
}
cout<<a[i]<<" ";
}
return 0;
}

set集

#include <iostream>
#include <set>

using namespace std;

int main(){
std::multiset<int> se;
int n;
int x;

cin>>n;
while(n--){
    scanf("%d",&x);
    se.insert(x);
}
//printf("%d\n",se.count(3));
//printf("%d\n",se.size());
//printf("%d\n",*se.lower_bound(3));
//printf("%d\n",*se.upper_bound(3));
//printf("%d\n",*se.find(3));
    std::set<int>::iterator it=se.end();//开
    it--;//set集左闭右开
    while(it!=se.begin()){
        printf("%d "*it);
        it--;
}
printf("%d\n",*it);
return 0;
}
发布了4 篇原创文章 · 获赞 1 · 访问量 63

猜你喜欢

转载自blog.csdn.net/weixin_45186911/article/details/103955435