Rumah pembangunan bahagian belakang C++ Menggunakan jadual hash untuk melaksanakan carian rentetan dalam C++

Menggunakan jadual hash untuk melaksanakan carian rentetan dalam C++

Aug 22, 2023 pm 12:03 PM
c++ Cari Hash jadual

Menggunakan jadual hash untuk melaksanakan carian rentetan dalam C++

Jadual cincang ialah struktur data yang sangat biasa yang memetakan nilai utama ke dalam jadual bersaiz tetap, membolehkan operasi carian, sisipan dan pemadaman yang cekap. Dalam C++, kita boleh menggunakan unordered_map dalam STL (Perpustakaan Templat Standard) untuk melaksanakan jadual cincang.

Dalam aplikasi praktikal, selalunya perlu melakukan operasi carian pada rentetan. Sebagai contoh, cari bilangan kejadian kata kunci tertentu dalam teks atau cari semua baris yang mengandungi rentetan tertentu. Untuk melaksanakan tugas ini dengan cekap, carian rentetan boleh dilaksanakan menggunakan jadual cincang.

Dalam artikel ini, kami akan memperkenalkan kaedah khusus menggunakan jadual cincang untuk melaksanakan carian rentetan dalam C++. Kami akan menggunakan contoh mencari bilangan kali rentetan muncul dalam teks.

Pertama, kita perlu mentakrifkan fungsi untuk memetakan rentetan ke dalam jadual cincang. Kaedah biasa ialah menggunakan nilai cincang rentetan sebagai nilai utama, dengan itu memastikan rentetan yang berbeza dipetakan ke lokasi yang berbeza. Untuk membolehkan fungsi cincang mempunyai prestasi yang baik, ia perlu dikira dengan cepat dan kejadian konflik cincang harus diminimumkan.

Berikut ialah pelaksanaan fungsi cincang mudah yang menambahkan kod ASCII rentetan dan mengambil baki:

size_t hash_func(const std::string& str) {
    size_t hash_val = 0;
    for (char c : str) {
        hash_val += static_cast<size_t>(c);
    }
    return hash_val % MAP_SIZE;
}

Seterusnya, kita perlu memasukkan setiap perkataan dalam teks ke dalam jadual cincang. Kita boleh memasukkan teks ke dalam jadual cincang dengan membahagikannya kepada perkataan mengikut ruang dan memanggil fungsi cincang. Memandangkan kata kunci mungkin muncul beberapa kali, kami perlu merekodkan bilangan kali setiap kata kunci muncul. Kita boleh menggunakan unordered_map untuk mencapai fungsi ini Jika nilai kunci sudah wujud semasa sisipan, nilai akan ditambah:

std::unordered_map<std::string, size_t> word_map;
for (std::string word : words) {
    if (word_map.find(word) == word_map.end()) {
        word_map[word] = 1;
    } else {
        ++word_map[word];
    }
}

Akhirnya, kita boleh mendapatkan kejadiannya dalam teks dengan memanggil nilai yang sepadan dengan rentetan dalam jadual cincang. Bilangan kali:

size_t count = word_map["target_string"];

Kod lengkap adalah seperti berikut:

#include 
#include 
#include 
#include 

const size_t MAP_SIZE = 1024;

size_t hash_func(const std::string& str) {
    size_t hash_val = 0;
    for (char c : str) {
        hash_val += static_cast<size_t>(c);
    }
    return hash_val % MAP_SIZE;
}

int main() {
    std::vector words {"hello", "world", "hello", "c++", "hash", "world", "world"};
    std::unordered_map word_map;

    for (std::string word : words) {
        if (word_map.find(word) == word_map.end()) {
            word_map[word] = 1;
        } else {
            ++word_map[word];
        }
    }

    size_t count = word_map["world"];
    std::cout << "The word 'world' appears " << count << " times." << std::endl;

    return 0;
}

Dengan kod di atas, kita boleh menggunakan jadual cincang untuk mengira dengan cepat bilangan kali rentetan muncul dalam teks. Penggunaan jadual cincang boleh meningkatkan prestasi carian, yang lebih jelas untuk jumlah data yang besar. Ia juga mempunyai fleksibiliti dan kebolehskalaan yang hebat dalam aplikasi praktikal.

Atas ialah kandungan terperinci Menggunakan jadual hash untuk melaksanakan carian rentetan 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
1596
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

Cara menggunakan ungkapan biasa dalam c Cara menggunakan ungkapan biasa dalam c Aug 12, 2025 am 10:46 AM

Untuk menggunakan ungkapan biasa di C, anda perlu memasukkan fail header dan menggunakan fungsi yang disediakan untuk pemadanan corak dan pemprosesan teks. 1. Gunakan std :: regex_match untuk memadankan rentetan penuh, dan kembali benar hanya apabila keseluruhan rentetan mematuhi corak; 2. Gunakan std :: regex_search untuk mencari perlawanan di mana -mana kedudukan dalam rentetan; 3. Gunakan std :: smatch untuk mengekstrak kumpulan penangkapan, dapatkan perlawanan lengkap melalui perlawanan [0], perlawanan [1] dan sub-perlawanan berikutnya; 4. Gunakan std :: regex_replace untuk menggantikan teks yang sepadan, dan menyokong kumpulan penangkapan dengan rujukan seperti $ 1 dan $ 2; 5. Anda boleh menambah ISET semasa membina regex (

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

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.

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

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.

Bagaimana untuk menulis asas makefile asas untuk projek c? Bagaimana untuk menulis asas makefile asas untuk projek c? Aug 15, 2025 am 11:17 AM

AbasicMakeFileAutomatesc CompilationByDefiningRulesWithTargets, Dependencies, andCommands.2.KeyComponentsincludevariablikeCxx, Cxxflags, Target, Srcs, AndobjStosimplifyConfiguration.3.ApaterSfingSoSoSe (%SsoSoSoSoSoSoSoSoSoS.

See all articles