首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >在c++中排序列表的最快方法是什么?

在c++中排序列表的最快方法是什么?
EN

Stack Overflow用户
提问于 2012-03-28 21:07:57
回答 4查看 232关注 0票数 1

我有一个结构体

代码语言:javascript
复制
typedef struct  
{ 
    int id;  
    string name;  
    string address;
    string city;  
    // ...
} Customer;

我将有多个客户,所以我需要将这些结构存储在某种列表中,然后我需要按id排序。这里可能有多种解决方案,我自己也有一些想法,但我正在寻找性能方面的最佳解决方案。

EN

回答 4

Stack Overflow用户

回答已采纳

发布于 2012-03-28 21:10:21

使用stl算法包提供的sort,示例:

代码语言:javascript
复制
struct Customer {
    int id;
    Customer(int i) : id(i) {}
};

bool sortfunc(struct Customer i, struct Customer j) {
    return (i.id < j.id);
}

int main() {
    vector<Customer> customers;
    customers.push_back(Customer(32));
    customers.push_back(Customer(71));
    customers.push_back(Customer(12));
    customers.push_back(Customer(45));
    customers.push_back(Customer(26));
    customers.push_back(Customer(80));
    customers.push_back(Customer(53));
    customers.push_back(Customer(33));

    sort(customers.begin(), customers.end(), sortfunc);

    cout << "customers:";
    vector<Customer>::iterator it;
    for (it = customers.begin(); it != customers.end(); ++it)
        cout << " " << it->id;

    return 1;
}
票数 9
EN

Stack Overflow用户

发布于 2012-03-28 21:14:26

我建议您将客户存储在std::set中。

您应该创建运算符<

代码语言:javascript
复制
bool Customer::operator < (const Customer& other) const {
    return id < customer.id;
}

现在,在每次插入之后,集合已经按id排序。

您可以通过以下方式遍历整个集合:

代码语言:javascript
复制
for(std::set<Customer>::iterator it = your_collection.begin(); it != your_collection.end(); it++)

这是最快的解决方案,因为您不需要对任何东西进行排序,并且每次插入都需要O(log )时间。

票数 4
EN

Stack Overflow用户

发布于 2012-03-28 21:10:12

使用std::list.sort方法应该是最快的方法。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/9908179

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档