qq_37859539
维1
采纳率66.7%
2017-05-03 15:13 阅读 5.3k

c++ stl 中sort对list容器的排序

#include
#include
#include

using namespace std;

void PrintList(list &l)
{
for (list::iterator corrent = l.begin(); corrent!=l.end(); corrent++)
{
/*int tmp = l.front();
cout << tmp << endl;*/
;
cout << *corrent << endl;
}
}

int compare(int &a,int &b)
{
return a < b;
}

int main()
{
list l;
for (int j = 0; j < 10; j++)
{
l.push_back(j);
//l.push_front(j);
}
sort(l.begin(), l.end());//这两个为什么都是错的???
sort(l.begin(), l.end(), compare);

getchar();
return 0;
}

/*错误    1   error C2784: “unknown-type std::operator -(std::move_iterator<_RanIt> &,const std::move_iterator<_RanIt2> &)”: 未能从“std::_List_iterator<std::_List_val<std::_List_simple_types<int>>>”为“std::move_iterator<_RanIt> &”推导 //模板 参数  f:\学习软件\vs2013\vc\include\algorithm 3157    1   List入门

*/

  • 点赞
  • 写回答
  • 关注问题
  • 收藏
  • 复制链接分享

8条回答 默认 最新

  • 已采纳
    u012926545 jsnhsu1971 2017-05-03 16:01

    std:sort() 所使用的容器必須能支持隨機存取, 如: std::vector

    你使用的 std::list 非隨機存取的容器, std::list 排序可使用 std::list::sort() 自帶的來完成.

    点赞 3 评论 复制链接分享
  • caozhy 从今以后生命中的每一秒都属于我爱的人 2017-05-03 15:48
  • crazyboy12138 crazyboy12138 2017-05-04 02:03

    list l;

    (list & l)

    list::iterator ...

    
    
    点赞 评论 复制链接分享
  • crazyboy12138 crazyboy12138 2017-05-04 02:04

    list。。。。。。。。。。。

    点赞 评论 复制链接分享
  • crazyboy12138 crazyboy12138 2017-05-04 02:04

    “list”

    点赞 评论 复制链接分享
  • crazyboy12138 crazyboy12138 2017-05-04 02:06

    有毒啊,< in t>显示不出来,,,得在int两边加空格

    点赞 评论 复制链接分享
  • crazyboy12138 crazyboy12138 2017-05-04 02:13

    看来是list不支持这样,直接l.sort(),或者l.sort( compare)就行

    点赞 评论 复制链接分享
  • zhang_guyuan jalen_zh 2017-05-05 08:26

    sort好像只能对连续空间存储的数据排序,例如数组,vector

    点赞 评论 复制链接分享

相关推荐