Rumah > Tutorial sistem > LINUX > Algoritma - Langkau Carian

Algoritma - Langkau Carian

WBOY
Lepaskan: 2024-02-16 10:42:02
ke hadapan
634 orang telah melayarinya

Algoritma - Langkau Carian

Sebagai contoh, katakan kita mempunyai array arr[] bersaiz n dan blok (untuk dilompat) bersaiz m. Kemudian kita mencari indeks arr[0], arr[m], arr[2m]... ..arr[km] dan seterusnya. Sebaik sahaja kita menemui selang (arr[km]

Kami mempertimbangkan tatasusunan berikut: (0,1,1,2,3,5,8,13,21,34,55,89,144,233,377,610). Panjang tatasusunan ialah 16. Carian langkau akan menemui 55 dalam langkah berikut, dengan mengandaikan saiz blok yang akan dilangkau ialah 4.

Langkah 1: Lompat dari indeks 0 ke indeks 4;
Langkah 2: Lompat dari indeks 4 ke indeks 8;
Langkah 3: Lompat dari indeks 8 ke indeks 16;
Langkah 4: Memandangkan elemen pada indeks 16 lebih besar daripada 55, kami akan kembali satu langkah ke indeks 9.
Langkah 5: Lakukan carian linear dari indeks 9 untuk mendapatkan elemen 55.
Apakah saiz ketulan optimum untuk dilangkau?
Dalam kes yang paling teruk kita perlu melakukan lompatan n/m dan melakukan perbandingan m-1 dengan carian linear jika nilai yang disemak terakhir adalah lebih besar daripada elemen yang dicari. Oleh itu, jumlah bilangan perbandingan kes terburuk ialah ((n/m) + m-1). Apabila m =√n, nilai fungsi ((n/m) + m-1) akan menjadi nilai minimum. Oleh itu, saiz langkah terbaik ialah m = √n.

// C++ program to implement Jump Search

#include <bits>
using namespace std;

int jumpSearch(int arr[], int x, int n)
{
// Finding block size to be jumped
int step = sqrt(n);

// Finding the block where element is
// present (if it is present)
int prev = 0;
while (arr[min(step, n)-1] = n)
return -1;
}

// Doing a linear search for x in block
// beginning with prev.
while (arr[prev] 
<p>Keluaran: </p>
<p>Nombor 55 berada pada indeks 10</p>
<p>Kerumitan masa: O(√n)<br>
Ruang tambahan: O(1)</p>
<p><strong>Perhatian:</strong></p>
<p>Carian ini hanya berfungsi pada tatasusunan yang diisih. <br>
Saiz optimum ketulan untuk dilangkau ialah O(√n). Ini menjadikan carian lompat O(√n) kerumitan masa. <br>
Kerumitan masa carian langkau adalah antara carian linear ((O(n))) dan carian binari (O(Log n) <br>
Carian binari adalah lebih baik daripada carian lompat, tetapi carian lompat mempunyai kelebihan yang kita lalui sekali sahaja (carian binari mungkin memerlukan paling banyak lompatan 0 (Log n), memandangkan elemen yang dicari adalah elemen terkecil atau kurang daripada terkecil). Oleh itu, dalam sistem yang melompat ke belakang adalah mahal, kami menggunakan Carian Lompat. </p></bits>
Salin selepas log masuk

Atas ialah kandungan terperinci Algoritma - Langkau Carian. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

sumber:linuxprobe.com
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
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan