Rumah pembangunan bahagian belakang C++ Cara menggunakan fungsi isihan dalam c++

Cara menggunakan fungsi isihan dalam c++

Mar 25, 2024 pm 05:58 PM
c++ susunan fungsi isihan

Fungsi isihan dalam C++ ialah fungsi perpustakaan algoritma STL yang berguna yang digunakan untuk mengisih elemen dalam bekas. Sintaks asasnya ialah: `sort(Iterator first, Iterator last)`, di mana pertama dan terakhir ialah iterator yang mentakrifkan kedudukan permulaan dan penamat bagi jujukan. Secara lalai, fungsi isihan diisih dalam tertib menaik, tetapi anda boleh menyesuaikan pengisihan dengan menyediakan fungsi perbandingan atau melebihkan `operator<`. Untuk objek jenis tersuai, fungsi perbandingan perlu disediakan.

Cara menggunakan fungsi isihan dalam c++

Dalam C++, fungsi isihan ialah fungsi yang sangat berguna dalam perpustakaan algoritma STL (Standard Template Library), yang digunakan untuk mengisih elemen dalam bekas. Fungsi ini ditakrifkan dalam fail pengepala jadi anda perlu memasukkan fail pengepala ini sebelum menggunakannya. Sintaks asas fungsi

isih adalah seperti berikut:

cpp

#include <algorithm>  
#include <vector>  
  
std::sort(Iterator first, Iterator last);

Di sini, pertama dan terakhir ialah iterator, yang mentakrifkan kedudukan permulaan dan penamat bagi urutan yang hendak diisih. Ambil perhatian bahawa lelaran terakhir menunjuk ke elemen seterusnya pada "kedudukan akhir" jujukan, jadi julat sebenar jujukan ialah [pertama, terakhir).

Fungsi isih mengisih elemen dalam tertib menaik secara lalai Jika anda perlu mengisih objek daripada jenis tersuai, anda mungkin perlu menyediakan fungsi perbandingan atau operator lebihan<.

Berikut ialah contoh mudah yang menunjukkan cara menggunakan fungsi isih untuk mengisih vektor:

cpp

#include <iostream>  
#include <vector>  
#include <algorithm>  
  
int main() {  
    std::vector<int> numbers = {5, 2, 8, 1, 9};  
      
    std::sort(numbers.begin(), numbers.end());  
      
    for (int num : numbers) {  
        std::cout << num << &#39; &#39;;  
    }  
      
    return 0;  
}

Atur cara ini akan mengeluarkan: 1 2 5 8 9, iaitu elemen dalam vektor nombor dalam menaik pesanan Hasil tersusun.

Jika anda perlu mengisih objek daripada jenis tersuai, anda perlu menyediakan fungsi perbandingan atau operator beban lampau<. Sebagai contoh, katakan anda mempunyai kelas Orang yang mempunyai pembolehubah ahli umur, dan anda ingin mengisih objek Orang mengikut umur:

cpp

#include <iostream>  
#include <vector>  
#include <algorithm>  
  
class Person {  
public:  
    std::string name;  
    int age;  
      
    Person(const std::string& name, int age) : name(name), age(age) {}  
      
    // 重载 operator< 以便 sort 可以使用  
    bool operator<(const Person& other) const {  
        return age < other.age;  
    }  
};  
  
int main() {  
    std::vector<Person> people = {  
        {"Alice", 30},  
        {"Bob", 20},  
        {"Charlie", 25}  
    };  
      
    std::sort(people.begin(), people.end());  
      
    for (const auto& person : people) {  
        std::cout << person.name << ": " << person.age << std::endl;  
    }  
      
    return 0;  
}

Program ini akan mengeluarkan nama dan umur setiap orang dalam susunan umur yang menaik. Ambil perhatian bahawa kami membebankan operator< supaya fungsi isihan tahu cara membandingkan objek Orang. Jika anda tidak mahu membebankan operator

Atas ialah kandungan terperinci Cara menggunakan fungsi isihan dalam c++. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan Laman Web ini
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

Alat AI Hot

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

Video Face Swap

Video Face Swap

Tukar muka dalam mana-mana video dengan mudah menggunakan alat tukar muka AI percuma kami!

Alat panas

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Topik panas

Tutorial PHP
1598
276
Apa yang perlu saya lakukan jika aplikasi tidak boleh bermula secara normal (0xc0000906)? Lihat penyelesaian di sini Apa yang perlu saya lakukan jika aplikasi tidak boleh bermula secara normal (0xc0000906)? Lihat penyelesaian di sini Aug 13, 2025 pm 06:42 PM

Apabila membuka perisian atau permainan, segera tiba -tiba muncul bahawa "aplikasi tidak boleh bermula secara normal (0xc0000906)" muncul, dan banyak pengguna akan dikelirukan dan tidak tahu di mana hendak bermula. Malah, kebanyakan kesilapan ini disebabkan oleh rasuah fail sistem atau perpustakaan runtime yang hilang. Jangan tergesa -gesa untuk memasang semula sistem. Artikel ini memberikan anda beberapa penyelesaian yang mudah dan berkesan untuk membantu anda memulihkan program dengan cepat. 1. Apakah ralat 0xc0000906? Kod Ralat 0xC0000906 adalah pengecualian permulaan yang biasa dalam sistem Windows, yang biasanya bermaksud bahawa program tidak dapat memuatkan komponen sistem yang diperlukan atau persekitaran yang berjalan ketika berjalan. Masalah ini sering berlaku apabila menjalankan perisian atau permainan besar. Sebab utama mungkin termasuk: Perpustakaan Runtime yang diperlukan tidak dipasang atau rosak. Pakej pemasangan perisian tidak berkesudahan

Pautan harga pecah melalui 24 USD Analisis Rintangan Utama: Fundamental Projek Chainlink dan Trend Harga Pautan harga pecah melalui 24 USD Analisis Rintangan Utama: Fundamental Projek Chainlink dan Trend Harga Aug 16, 2025 pm 12:15 PM

Kandungan: Trend harga semasa dan isyarat teknikal utama untuk memacu pautan faktor teras dan dana institusi mekanisme rizab strategik yang kuat menguatkan jangkaan deflasi gergasi kewangan tradisional mengadopsi asas-asas projek pengembangan ekologi yang dipercepatkan secara revolusi dan secara bertelagaman. $ 24.64, sasaran seterusnya Link ialah Fibonacci 0.786 Tahap Retracement 26.46, yang boleh mencabar 2024 tinggi $ 30.93 selepas terobosan. Sokongan utama

Bagaimana cara membetulkan msvcp71.dll yang hilang di komputer anda? Hanya ada tiga kaedah yang diperlukan Bagaimana cara membetulkan msvcp71.dll yang hilang di komputer anda? Hanya ada tiga kaedah yang diperlukan Aug 14, 2025 pm 08:03 PM

Komputer meminta "MSVCP71.dll hilang dari komputer", yang biasanya kerana sistem tidak mempunyai komponen yang kritikal, yang menyebabkan perisian tidak dimuatkan secara normal. Artikel ini akan menganalisis fungsi fail dan punca akar kesilapan, dan menyediakan tiga penyelesaian yang cekap untuk membantu anda memulihkan program dengan cepat. 1. Apakah msvcp71.dll? MSVCP71.dll tergolong dalam fail Perpustakaan Runtime Core Microsoft Visualc 2003 dan tergolong dalam jenis Perpustakaan Link Dinamik (DLL). Ia digunakan terutamanya untuk menyokong program yang ditulis dalam C untuk memanggil fungsi standard, templat STL dan modul pemprosesan data asas. Banyak aplikasi dan permainan klasik yang dibangunkan pada awal 2000 -an bergantung pada fail ini untuk dijalankan. Setelah fail hilang atau rosak,

Contoh Operator Operator Contoh Contoh Operator Operator Contoh Aug 15, 2025 am 10:18 AM

Pengendali yang berlebihan dalam C membolehkan tingkah laku baru pengendali standard untuk ditugaskan kepada jenis tersuai, 1 mengembalikan objek baru melalui fungsi ahli yang berlebihan; 2. Overload = Ubah suai objek semasa dan rujukan pulangan; 3. Fungsi rakan terlalu banyak

std :: peta vs std :: unordered_map di c std :: peta vs std :: unordered_map di c Aug 14, 2025 pm 06:53 PM

Dalam C, pilihan std :: peta dan std :: unordered_map bergantung kepada keperluan khusus. 1. Struktur asas yang berbeza: STD :: MAP dilaksanakan berdasarkan pokok merah dan hitam, dengan kekunci yang disimpan dalam urutan, urutan menaik lalai, dan kerumitan carian dan penyisipan adalah O (logn); std :: unordered_map menggunakan jadual hash, tidak teratur, dan kerumitan purata carian dan penyisipan adalah O (1), dan yang paling teruk ialah O (n). 2. Prestasi penyisipan dan overhead memori: Sisipan peta memerlukan penyelenggaraan struktur pokok dan kurang efisien; Penyisipan Unordered_map lebih cepat tetapi menggunakan lebih banyak ingatan, dan boleh dioptimumkan melalui rizab (). 3. Fungsi perbandingan tersuai: peta menyokong fungsi perbandingan tersuai, tidak teratur

C vektor contoh rentetan C vektor contoh rentetan Aug 21, 2025 am 04:02 AM

Penggunaan asas std :: vektor termasuk: 1. Mengisytiharkan vektor; 2. Tambah elemen dengan push_back (); 3. Inisialisasi dengan senarai permulaan; 4. Loop traversal dengan julat untuk; 5. Unsur akses melalui indeks atau belakang (); 6. Penugasan nilai langsung untuk mengubah suai elemen; 7. Padam elemen akhir dengan pop_back (); 8. Saiz panggilan () untuk mendapatkan bilangan elemen; Adalah disyorkan untuk menggunakan Constauto & untuk mengelakkan menyalin, memperuntukkan Rizab () untuk meningkatkan prestasi, dan memberi perhatian untuk memeriksa bahawa ia tidak kosong sebelum akses. Struktur data ini adalah cara yang cekap dan pilihan untuk mengendalikan senarai rentetan.

Cara bekerja dengan std :: varian dalam c Cara bekerja dengan std :: varian dalam c Aug 14, 2025 am 11:32 AM

STD :: VARIANT adalah kesatuan selamat jenis yang diperkenalkan oleh C 17. Ia dengan selamat boleh memegang nilai salah satu jenis yang ditentukan. Ia dapat merealisasikan akses selamat dan jenis pemeriksaan melalui kaedah seperti std :: get, std :: holds_alternative, std :: visit and std :: get_if. Digabungkan dengan STD :: monostate, nilai pilihan boleh disimulasikan. Adalah disyorkan untuk menggunakan STD :: Lawatan untuk Pengedaran Jenis dan mengelakkan senarai jenis yang besar untuk meningkatkan penyelenggaraan, dan akhirnya memastikan keselamatan jenis dan pengecualian jenis.

Apakah nisbah emas dalam bulatan mata wang? Bagaimana cara menggunakan poket emas Fibonacci? Apakah nisbah emas dalam bulatan mata wang? Bagaimana cara menggunakan poket emas Fibonacci? Aug 14, 2025 pm 01:42 PM

Apakah nisbah emas dalam katalog? Dari Fei ke Poket Emas: Cara Menunjukkan Corak Cara Menggunakan Poket Emas Dalam Dagangan Cryptocurrency Cara Menggunakan Poket Emas Mengapa Nisbah Emas Berfungsi Di Pasaran Kewangan Financialfebonacci Contoh Perdagangan Emas Depan dengan Poket Emas dan Petunjuk Teknikal yang lain. Zon Emas Fibonacci? 2. Mengapa 0.618 penting dalam perdagangan cryptocurrency? 3. Adakah nisbah emas berkesan? 4. Cara Tradingvie

See all articles