在c ++中对某种列表进行排序的最快方法是什么?

时间:2012-03-28 13:07:57

标签: c++ performance list sorting data-structures

我有一个结构

typedef struct  
{ 
    int id;  
    string name;  
    string address;
    string city;  
    // ...
} Customer;

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

4 个答案:

答案 0 :(得分:10)

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

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;
}

答案 1 :(得分:4)

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

您应该创建运算符&lt;

bool Customer::operator < (const Customer& other) const {
    return id < customer.id;
}

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

你可以通过以下方式迭代整个集合:

for(std::set<Customer>::iterator it = your_collection.begin(); it != your_collection.end(); it++)

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

答案 2 :(得分:0)

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

答案 3 :(得分:0)

为您的结构定义operator<,以提供Customer个实例之间的排序关系:

struct Customer {

    ...

    friend bool operator<(const Customer& a, const Customer& b) {
        return a.id < b.id;
    }

};

使用this cheatsheet(特别是底部的流程图)来决定您应该在特定程序中使用哪个容器。如果是std::set,只要您将Customer插入set,就会完成排序。如果是std::list,请调用列表中的sort()成员函数:

std::list<Customer> customers;
customers.push_back(Customer(...));
...
customers.sort();

如果是std::vectorstd::deque,请使用std::sort()标题中的<algorithm>

std::vector<Customer> customers;
customers.push_back(Customer(...));
...
std::sort(customers.begin(), customers.end());

如果需要以多种方式排序,请为每个排序定义排序函数:

struct Customer {

    ...

    static bool sort_by_name(const Customer& a, const Customer& b) {
        return a.name < b.name;
    }

};

然后告诉std::list::sort()std::sort()使用该比较器:

customers.sort(Customer::sort_by_name);

std::sort(customers.begin(), customers.end(), Customer::sort_by_name);