如何在结构体(类)中对结构体(类)中的结构体数组使用sort?

struct st{
  struct node{
     int x;
  }a[1000];
  int cmp(st::node c, st::node d)
  {
     return c.x < d.x;
  }
  void init(int n )
  {
     sort(a+1,a+1+n,st::cmp);
  }
};

这样会报错,该如何解决

报什么错误,cmp的参数好像是引用传值的。

问题:标准库中的sort的原型如下
void sort ( RandomAccessIterator first, RandomAccessIterator last,Compare comp );
要求first和last迭代器都要有加1的功能,而你的代码中的node*没有相关的+1操作。
如下代码可以证明问题

#include<algorithm>
struct st{
  struct node{
     int x=1;
  };
  node a[1000];
};
using std::cout;
int main()
{
    st A;
    sort()
    cout<<*(A.a++);
    return 0;
}

编译错误
21 13 E:\DEV CPP\HELLO.cpp [Error] lvalue required as increment operand

  • dynamic in c#
  • 如何指定树莓派上QT图形输出的设备?
  • C/C++程序的存储空间布局
  • `(x+7)&~7`,把x增大为稍大于x的8的倍数。这怎么理解?
  • C++中静态成员变量如何访问?
  • union在内存中的表现形式?
  • C++中的"%:"和"%:%:"如何使用?
  • TCP网络编程一般都是怎么封包解包的? 怎么才能解决不同平台的字节序和不同整数大小的问题?
  • 如果我有一个file1.h和file1.c,那么包含的头文件应该怎么安排?
  • 关于二叉树遍历的问题。
  • cmake+qt+opencv老是配置不成功