Rumah >pembangunan bahagian belakang >C++ >Bagaimanakah saya Boleh Menyusun std::map mengikut Nilai dalam C ?

Bagaimanakah saya Boleh Menyusun std::map mengikut Nilai dalam C ?

DDD
DDDasal
2024-11-30 19:01:121063semak imbas

How Can I Sort an std::map by Value in C  ?

Mengisih std::map mengikut Nilai

Soalan: Bagaimanakah saya boleh mengisih std::map dengan mudah berdasarkannya nilai?

Jawapan:

Pendekatan Tradisional (Sebelum C 11)

Sebelum pengenalan C 11, mengisih peta mengikut nilai memerlukan langkah perantara untuk menukar std::map menjadi a std::pasangan. Ini melibatkan penggunaan fungsi isihan tersuai dan menentukan parameter perbandingan secara manual.

Pendekatan C 11

Dengan kemunculan C 11, penyelesaian yang lebih bersih muncul. Coretan kod berikut menunjukkan cara:

template<typename A, typename B>
std::multimap<B,A> flip_map(const std::map<A,B> &src)
{
    std::multimap<B,A> dst;
    std::transform(src.begin(), src.end(), std::inserter(dst, dst.begin()),
                   flip_pair<A,B>);
    return dst;
}

Fungsi ini secara berkesan membalikkan pasangan nilai kunci dalam peta, membolehkan anda mengulangi nilai yang diisih.

Sumber Bersekutu Generik (C 11 dan Ke Atas)

Untuk lebih fleksibiliti, kaedah generik versi fungsi flipping boleh dibuat, membenarkan ia berfungsi dengan mana-mana bekas bersekutu:

template<typename A, typename B, template<class,class,class...> class M, class... Args>
std::multimap<B,A> flip_map(const M<A,B,Args...> &src)
{
    std::multimap<B,A> dst;
    std::transform(src.begin(), src.end(),
                   std::inserter(dst, dst.begin()),
                   flip_pair<A,B>);
    return dst;
}

Fungsi ini mengambil mana-mana kelas bekas bersekutu sebagai input, menjadikannya mudah untuk digunakan dengan kedua-dua std::map dan std ::unordered_map.

Atas ialah kandungan terperinci Bagaimanakah saya Boleh Menyusun std::map mengikut Nilai dalam C ?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn