Rumah pembangunan bahagian belakang C++ Penjelasan terperinci tentang fungsi pengisihan dalam C++

Penjelasan terperinci tentang fungsi pengisihan dalam C++

Nov 18, 2023 pm 03:51 PM
c++ Penjelasan terperinci Fungsi menyusun

Penjelasan terperinci tentang fungsi pengisihan dalam C++

Fungsi isih dalam C++ ialah fungsi berfungsi yang digunakan untuk mengisih elemen dalam tatasusunan atau bekas. Isih boleh dalam tertib menaik atau menurun, dan pelbagai jenis data seperti integer, titik terapung dan jenis aksara boleh diisih. Bahasa C++ menyediakan pelbagai fungsi pengisihan Artikel ini akan memperkenalkan penggunaan dan ciri-ciri fungsi pengisihan ini secara terperinci.

  1. fungsi sort()

fungsi sort() ialah salah satu fungsi pengisihan yang paling biasa digunakan dalam C++ STL Fungsinya adalah untuk menyusun elemen dalam tatasusunan atau bekas. Penggunaan asas fungsi sort() adalah seperti berikut:

sort(begin, end);
Salin selepas log masuk

di mana permulaan ialah alamat elemen pertama dalam tatasusunan atau bekas, penghujung ialah alamat elemen terakhir + 1, jadi hujung menunjuk ke alamat kosong selepas elemen terakhir. Fungsi sort() diisih dalam tertib menaik secara lalai Jika anda perlu mengisih dalam tertib menurun, anda boleh memasukkan penuding fungsi atau ungkapan lambda sebagai parameter ketiga.

Berikut ialah contoh kod yang menunjukkan cara menggunakan fungsi sort() untuk mengisih tatasusunan integer:

#include <iostream>
#include <algorithm>

using namespace std;

int main()
{
    int arr[] = {5, 2, 9, 1, 4, 3, 8, 6, 7};
    int n = sizeof(arr) / sizeof(arr[0]);

    sort(arr, arr + n);

    for (int i = 0; i < n; i++)
    {
        cout << arr[i] << " ";
    }

    return 0;
}
Salin selepas log masuk

Hasil menjalankan kod di atas adalah seperti berikut:

1 2 3 4 5 6 7 8 9
Salin selepas log masuk
Salin selepas log masuk
Salin selepas log masuk
  1. stable_sort() fungsi
_

stable () function dan sort( ) fungsi adalah serupa, tetapi ia memastikan kedudukan relatif elemen dengan nilai yang sama kekal tidak berubah selepas mengisih. Penggunaan fungsi stable_sort() adalah serupa dengan fungsi sort() Anda juga boleh menghantar penunjuk fungsi atau ungkapan lambda sebagai parameter ketiga. Berikut ialah contoh kod:

#include <iostream>
#include <algorithm>

using namespace std;

int main()
{
    int arr[] = {5, 2, 9, 1, 4, 3, 8, 6, 7};
    int n = sizeof(arr) / sizeof(arr[0]);

    stable_sort(arr, arr + n);

    for (int i = 0; i < n; i++)
    {
        cout << arr[i] << " ";
    }

    return 0;
}
Salin selepas log masuk

Hasil menjalankan kod di atas adalah seperti berikut:

1 2 3 4 5 6 7 8 9
Salin selepas log masuk
Salin selepas log masuk
Salin selepas log masuk
  1. partial_sort() function

partial_sort() fungsi boleh mengisih sebahagian elemen dalam tatasusunan atau bekas, iaitu, susun k unsur terkecil teratas dalam tatasusunan di hadapan (atau susun k unsur terbesar di hadapan tatasusunan). Penggunaannya adalah seperti berikut:

partial_sort(begin, middle, end);
Salin selepas log masuk

di mana bermula ialah alamat elemen pertama dalam tatasusunan atau bekas, hujung ialah alamat elemen terakhir + 1, dan tengah ialah lelaran yang menunjuk ke elemen ke-k. Perlu diingatkan bahawa fungsi partial_sort() hanya menjamin bahawa elemen k pertama disusun, dan susunan elemen yang selebihnya tidak ditentukan. Berikut ialah contoh kod:

#include <iostream>
#include <algorithm>

using namespace std;

int main()
{
    int arr[] = {5, 2, 9, 1, 4, 3, 8, 6, 7};
    int n = sizeof(arr) / sizeof(arr[0]);

    int k = 3;

    partial_sort(arr, arr + k, arr + n);

    for (int i = 0; i < k; i++)
    {
        cout << arr[i] << " ";
    }

    return 0;
}
Salin selepas log masuk

Hasil menjalankan kod di atas adalah seperti berikut:

1 2 3
Salin selepas log masuk
  1. nth_element() function

nth_element() fungsi digunakan untuk memilih elemen kth terkecil (atau kth terbesar) dalam tatasusunan atau bekas, dan Susunkannya pada kedudukan ke-k dalam tatasusunan. Penggunaannya adalah seperti berikut:

nth_element(begin, middle, end);
Salin selepas log masuk

di mana bermula ialah alamat elemen pertama dalam tatasusunan atau bekas, hujung ialah alamat elemen terakhir + 1, dan tengah ialah lelaran yang menunjuk ke elemen ke-k. Perlu diingatkan bahawa fungsi nth_element() hanya menjamin bahawa elemen k pertama tatasusunan disusun, manakala elemen kth tidak diisih. Berikut ialah contoh kod:

#include <iostream>
#include <algorithm>

using namespace std;

int main()
{
    int arr[] = {5, 2, 9, 1, 4, 3, 8, 6, 7};
    int n = sizeof(arr) / sizeof(arr[0]);

    int k = 3;

    nth_element(arr, arr + k - 1, arr + n);

    cout << "第 " << k << " 小的数是:" << arr[k - 1] << endl;

    return 0;
}
Salin selepas log masuk

Hasil menjalankan kod di atas adalah seperti berikut:

第 3 小的数是:3
Salin selepas log masuk
  1. make_heap() function

make_heap() function boleh menukar tatasusunan atau bekas menjadi timbunan, iaitu, elemen dalam tatasusunan mengikut peraturan timbunan binari Diisih untuk menyokong operasi timbunan. Penggunaannya adalah seperti berikut:

make_heap(begin, end);
Salin selepas log masuk

di mana bermula ialah alamat elemen pertama dalam tatasusunan atau bekas, dan penghujungnya ialah alamat elemen terakhir + 1. Berikut ialah contoh kod:

#include <iostream>
#include <algorithm>

using namespace std;

int main()
{
    int arr[] = {5, 2, 9, 1, 4, 3, 8, 6, 7};
    int n = sizeof(arr) / sizeof(arr[0]);

    make_heap(arr, arr + n);

    for (int i = 0; i < n; i++)
    {
        cout << arr[i] << " ";
    }

    return 0;
}
Salin selepas log masuk

Hasil menjalankan kod di atas adalah seperti berikut:

9 7 8 6 4 3 5 1 2
Salin selepas log masuk
  1. push_heap() function

push_heap() fungsi boleh memasukkan elemen baru ke dalam timbunan dan melaraskan semula struktur timbunan untuk memenuhi sifat timbunan. Penggunaannya adalah seperti berikut:

push_heap(begin, end);
Salin selepas log masuk

di mana bermula ialah alamat elemen pertama dalam tatasusunan atau bekas, dan penghujung ialah alamat elemen terakhir. Perlu diingatkan bahawa elemen baru yang dimasukkan harus diletakkan pada kedudukan terakhir timbunan. Berikut ialah contoh kod:

#include <iostream>
#include <algorithm>

using namespace std;

int main()
{
    int arr[] = {5, 2, 9, 1, 4, 3, 8, 6, 7};
    int n = sizeof(arr) / sizeof(arr[0]);

    make_heap(arr, arr + n);

    arr[n] = 0;

    push_heap(arr, arr + n + 1);

    for (int i = 0; i < n + 1; i++)
    {
        cout << arr[i] << " ";
    }

    return 0;
}
Salin selepas log masuk

Hasil menjalankan kod di atas adalah seperti berikut:

9 7 8 6 4 3 5 1 2 0
Salin selepas log masuk
  1. pop_heap() function

pop_heap() fungsi digunakan untuk meletuskan elemen atas timbunan dan melaraskan semula struktur timbunan untuk memenuhi sifat timbunan . Penggunaannya adalah seperti berikut:

pop_heap(begin, end);
Salin selepas log masuk

di mana bermula ialah alamat elemen pertama dalam tatasusunan atau bekas, dan penghujung ialah alamat elemen terakhir. Perlu diingat bahawa selepas memunculkan elemen atas timbunan, saiz timbunan harus dikurangkan sebanyak 1. Berikut ialah contoh kod:

#include <iostream>
#include <algorithm>

using namespace std;

int main()
{
    int arr[] = {5, 2, 9, 1, 4, 3, 8, 6, 7};
    int n = sizeof(arr) / sizeof(arr[0]);

    make_heap(arr, arr + n);

    pop_heap(arr, arr + n);

    n--;

    for (int i = 0; i < n; i++)
    {
        cout << arr[i] << " ";
    }

    return 0;
}
Salin selepas log masuk

Hasil menjalankan kod di atas adalah seperti berikut:

8 7 5 6 4 3 2 1
Salin selepas log masuk
  1. fungsi sort_heap()

fungsi sort_heap() digunakan untuk mengisih timbunan dan memastikan tatasusunan yang diisih berada dalam tertib menaik. Penggunaannya adalah seperti berikut:

sort_heap(begin, end);
Salin selepas log masuk

di mana bermula ialah alamat elemen pertama dalam tatasusunan atau bekas, dan penghujung ialah alamat elemen terakhir. Perlu diingatkan bahawa fungsi sort_heap() akan terlebih dahulu memanggil fungsi pop_heap() untuk meletuskan elemen atas timbunan sebelum mengisih timbunan, jadi saiz tatasusunan yang diisih hendaklah dikurangkan sebanyak 1. Berikut ialah contoh kod:

#include <iostream>
#include <algorithm>

using namespace std;

int main()
{
    int arr[] = {5, 2, 9, 1, 4, 3, 8, 6, 7};
    int n = sizeof(arr) / sizeof(arr[0]);

    make_heap(arr, arr + n);

    sort_heap(arr, arr + n);

    for (int i = 0; i < n; i++)
    {
        cout << arr[i] << " ";
    }

    return 0;
}
Salin selepas log masuk

Hasil menjalankan kod di atas adalah seperti berikut:

1 2 3 4 5 6 7 8 9
Salin selepas log masuk
Salin selepas log masuk
Salin selepas log masuk

Ringkasan

Artikel ini memperkenalkan secara terperinci fungsi pengisihan biasa dalam C++, termasuk sort(), stable_sort(), partial_sort( ), nth_element(), make_heap (), push_heap(), pop_heap() dan fungsi sort_heap(). Setiap fungsi pengisihan ini mempunyai ciri tersendiri dan boleh memenuhi keperluan pengisihan yang berbeza. Dalam pengaturcaraan sebenar, adalah sangat penting untuk memilih fungsi pengisihan yang sesuai mengikut situasi tertentu.

Atas ialah kandungan terperinci Penjelasan terperinci tentang fungsi pengisihan 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

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.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

AI Hentai Generator

AI Hentai Generator

Menjana ai hentai secara percuma.

Artikel Panas

R.E.P.O. Kristal tenaga dijelaskan dan apa yang mereka lakukan (kristal kuning)
2 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
Repo: Cara menghidupkan semula rakan sepasukan
4 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island Adventure: Cara mendapatkan biji gergasi
4 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌

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)

Reka letak objek C++ diselaraskan dengan memori untuk mengoptimumkan kecekapan penggunaan memori Reka letak objek C++ diselaraskan dengan memori untuk mengoptimumkan kecekapan penggunaan memori Jun 05, 2024 pm 01:02 PM

Susun atur objek C++ dan penjajaran memori mengoptimumkan kecekapan penggunaan memori: Susun atur objek: ahli data disimpan dalam susunan pengisytiharan, mengoptimumkan penggunaan ruang. Penjajaran memori: Data diselaraskan dalam memori untuk meningkatkan kelajuan akses. Kata kunci alignas menentukan penjajaran tersuai, seperti struktur CacheLine yang dijajarkan 64 bait, untuk meningkatkan kecekapan akses talian cache.

Bagaimana untuk melaksanakan pembanding tersuai dalam C++ STL? Bagaimana untuk melaksanakan pembanding tersuai dalam C++ STL? Jun 05, 2024 am 11:50 AM

Melaksanakan pembanding tersuai boleh dicapai dengan mencipta kelas yang membebankan operator(), yang menerima dua parameter dan menunjukkan hasil perbandingan. Sebagai contoh, kelas StringLengthComparator mengisih rentetan dengan membandingkan panjangnya: Buat kelas dan operator beban lampau(), mengembalikan nilai Boolean yang menunjukkan hasil perbandingan. Menggunakan pembanding tersuai untuk mengisih dalam algoritma bekas. Pembanding tersuai membolehkan kami mengisih atau membandingkan data berdasarkan kriteria tersuai, walaupun kami perlu menggunakan kriteria perbandingan tersuai.

Bagaimana untuk melaksanakan Corak Reka Bentuk Strategi dalam C++? Bagaimana untuk melaksanakan Corak Reka Bentuk Strategi dalam C++? Jun 06, 2024 pm 04:16 PM

Langkah-langkah untuk melaksanakan corak strategi dalam C++ adalah seperti berikut: tentukan antara muka strategi dan isytiharkan kaedah yang perlu dilaksanakan. Buat kelas strategi khusus, laksanakan antara muka masing-masing dan sediakan algoritma yang berbeza. Gunakan kelas konteks untuk memegang rujukan kepada kelas strategi konkrit dan melaksanakan operasi melaluinya.

Persamaan dan Perbezaan antara Golang dan C++ Persamaan dan Perbezaan antara Golang dan C++ Jun 05, 2024 pm 06:12 PM

Golang dan C++ masing-masing adalah sampah yang dikumpul dan bahasa pengaturcaraan pengurusan memori manual, dengan sistem sintaks dan jenis yang berbeza. Golang melaksanakan pengaturcaraan serentak melalui Goroutine, dan C++ melaksanakannya melalui benang. Pengurusan memori Golang adalah mudah, dan C++ mempunyai prestasi yang lebih kukuh. Dalam kes praktikal, kod Golang adalah lebih ringkas dan C++ mempunyai kelebihan prestasi yang jelas.

Bagaimana untuk menyalin bekas C++ STL? Bagaimana untuk menyalin bekas C++ STL? Jun 05, 2024 am 11:51 AM

Terdapat tiga cara untuk menyalin bekas C++ STL: Gunakan pembina salinan untuk menyalin kandungan bekas ke bekas baharu. Gunakan pengendali tugasan untuk menyalin kandungan bekas ke bekas sasaran. Gunakan algoritma std::copy untuk menyalin elemen dalam bekas.

Apakah prinsip pelaksanaan asas penunjuk pintar C++? Apakah prinsip pelaksanaan asas penunjuk pintar C++? Jun 05, 2024 pm 01:17 PM

Penunjuk pintar C++ melaksanakan pengurusan memori automatik melalui pengiraan penunjuk, pemusnah dan jadual fungsi maya. Kiraan penunjuk menjejaki bilangan rujukan, dan apabila bilangan rujukan menurun kepada 0, pemusnah mengeluarkan penunjuk asal. Jadual fungsi maya membolehkan polimorfisme, membenarkan gelagat khusus dilaksanakan untuk pelbagai jenis penunjuk pintar.

Bagaimana untuk melaksanakan pengendalian pengecualian bersarang dalam C++? Bagaimana untuk melaksanakan pengendalian pengecualian bersarang dalam C++? Jun 05, 2024 pm 09:15 PM

Pengendalian pengecualian bersarang dilaksanakan dalam C++ melalui blok try-catch bersarang, membenarkan pengecualian baharu dibangkitkan dalam pengendali pengecualian. Langkah-langkah cuba-tangkap bersarang adalah seperti berikut: 1. Blok cuba-tangkap luar mengendalikan semua pengecualian, termasuk yang dilemparkan oleh pengendali pengecualian dalam. 2. Blok cuba-tangkap dalam mengendalikan jenis pengecualian tertentu, dan jika pengecualian luar skop berlaku, kawalan diberikan kepada pengendali pengecualian luaran.

Bagaimana untuk melaksanakan pengaturcaraan berbilang benang C++ berdasarkan model Aktor? Bagaimana untuk melaksanakan pengaturcaraan berbilang benang C++ berdasarkan model Aktor? Jun 05, 2024 am 11:49 AM

Pelaksanaan pengaturcaraan berbilang benang C++ berdasarkan model Actor: Cipta kelas Actor yang mewakili entiti bebas. Tetapkan baris gilir mesej di mana mesej disimpan. Mentakrifkan kaedah untuk Pelakon menerima dan memproses mesej daripada baris gilir. Cipta objek Pelakon dan mulakan utas untuk menjalankannya. Hantar mesej kepada Pelakon melalui baris gilir mesej. Pendekatan ini menyediakan konkurensi, kebolehskalaan dan pengasingan yang tinggi, menjadikannya sesuai untuk aplikasi yang perlu mengendalikan sejumlah besar tugas selari.

See all articles