对向量结构进行排序 C++

问题描述

有没有办法对向量结构进行排序?鉴于我的结构看起来像这样

struct Data
{
    std::vector<std::string> Dates;
    std::vector<double> DateSeconds,other1,other2,other3,other4,other5;
};

我的排序方式(让我们取 DateSeconds)是,

int __cdecl CompareWithDateSeconds(const void* lhs,const void* rhs)
{
    for (int i = 0; i < m_DataSize; i++) {
        const Data* a = (const Data*)lhs;
        const Data* b = (const Data*)rhs;
        double delta = a->DateSeconds[i] - b->DateSeconds[i];

        if (delta > 0)
            return (SortDirection == Ascending) ? +1 : -1;
        if (delta < 0)
            return (SortDirection == Ascending) ? -1 : +1;
    }
}

然后

qsort(&m_Data.DateSeconds[0],m_DataSize,sizeof(m_Data.DateSeconds[0]),CompareWithDateSeconds);

解决方法

暂无找到可以解决该程序问题的有效方法,小编努力寻找整理中!

如果你已经找到好的解决方法,欢迎将解决方案带上本链接一起发送给小编。

小编邮箱:dio#foxmail.com (将#修改为@)

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...