如何解决对向量结构进行排序 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 举报,一经查实,本站将立刻删除。