stl中sort的排序从大到小怎么排

#include<iostream>#include<list>#include<algorithm>usingnamespacestd;intmain(){inta[]... #include<iostream>
#include<list>
#include<algorithm>
using namespace std;
int main(){
int a[]={8,2,3,1,9};
list<int>l1;
list<int>::iterator p;
for(int i=0;i<5;i++)
l1.push_back(a[i]);
l1.sort();
//l1.sort(l1.begin(),l1.end(),greater<int>);
for(p=l1.begin();p!=l1.end();p++)
cout<<*p;
cout<<endl;
return 0;
}
就是用容器从大到小怎么排啊 直接贴图 谢谢啊(急!急!急!)
stl中有的函数括号中是op例如sort(op),unique(op)意思明白就是不会用那位给讲讲啊 最好是把他们的从大到小用例子贴出来 谢谢啊
展开
 我来答
buptcxy
2010-05-25
知道答主
回答量:56
采纳率:0%
帮助的人:18.6万
展开全部
#include <list>
#include <iostream>
using namespace std;

int main( )
{
list <int> c1;
list <int>::iterator c1_Iter;

int num,var;//for input num and var for the list

cout << "输入需要排序的个数:" ;
cin >> num;

for(int i=0;i<num;i++)
{
var = 0;
cout << "输入第" << i+1 << "个数:";
cin >> var;

c1.push_back(var);
}

cout << "排序前:";
for ( c1_Iter = c1.begin( ); c1_Iter != c1.end( ); c1_Iter++ )
cout << " " << *c1_Iter;
cout << endl;

c1.sort( );
cout << "排序后:";
for ( c1_Iter = c1.begin( ); c1_Iter != c1.end( ); c1_Iter++ )
cout << " " << *c1_Iter;
cout << endl;

c1.sort( greater<int>( ) );//注意这行
cout << "按照降序重新排序是:";
for ( c1_Iter = c1.begin( ); c1_Iter != c1.end( ); c1_Iter++ )
cout << " " << *c1_Iter;
cout << endl;

// cin >> num; //留住屏幕结果
return 0;
}
BlueWanderer
推荐于2018-05-15 · TA获得超过9209个赞
知道大有可为答主
回答量:5673
采纳率:83%
帮助的人:1957万
展开全部
你只是sort写法错了

#include<iostream>
#include<list>
#include<algorithm>
using namespace std;
int main(){
int a[]={8,2,3,1,9};
list<int>l1;
list<int>::iterator p;
for(int i=0;i<5;i++)
l1.push_back(a[i]);
l1.sort(greater<int>());
for(p=l1.begin();p!=l1.end();p++)
cout<<*p;
cout<<endl;
return 0;
}
本回答被提问者和网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
wangtk1982
2010-05-15 · TA获得超过3742个赞
知道大有可为答主
回答量:3206
采纳率:100%
帮助的人:1412万
展开全部
#include<iostream>
#include<list>
#include<algorithm>
using namespace std;
int main(){
int a[]={8,2,3,1,9};
list<int>l1;
list<int>::iterator p;
for(int i=0;i<5;i++)
l1.push_back(a[i]);
l1.sort();
l1.reverse();
for(p=l1.begin();p!=l1.end();p++)
cout<<*p;
cout<<endl;
return 0;
}
或者

#include<iostream>
#include<list>
#include<algorithm>
using namespace std;
int main(){
int a[]={8,2,3,1,9};
list<int>l1;
list<int>::reverse_iterator p;
for(int i=0;i<5;i++)
l1.push_back(a[i]);
l1.sort();
for(p=l1.rbegin();p!=l1.rend();p++)
cout<<*p;
cout<<endl;
return 0;
}
最简单办法~
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
贯俊蔺易槐
2019-05-13 · TA获得超过3882个赞
知道大有可为答主
回答量:3114
采纳率:33%
帮助的人:177万
展开全部
你只是sort写法错了
#include<iostream>
#include<list>
#include<algorithm>
using
namespace
std;
int
main(){
int
a[]={8,2,3,1,9};
list<int>l1;
list<int>::iterator
p;
for(int
i=0;i<5;i++)
l1.push_back(a[i]);
l1.sort(greater<int>());
for(p=l1.begin();p!=l1.end();p++)
cout<<*p;
cout<<endl;
return
0;
}
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(2)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式