DSA Material

Data Structures Ma'lumotlar tuzilmalari
Algorithms Algoritmlar

Qidirish (Searching)

Share to

Qidirish (Searching) deganda berilgan ma'lumotlar to'plami (dataset) ichidan maqsadli elementni (target) aniqlash tushuniladi.

Ketma-ket qidirish (Linear Search)

Har qanday (tartiblangan yoki tartiblanmagan) massiv ustida ishlayveradi.

def linear_search(nums, target):
    for i, x in enumerate(nums):
        if x == target:
            return i
    return -1

nums = [4, 1, 7, 9]
print(linear_search(nums, 7))  # 2
print(linear_search(nums, 5))  # -1

Ikkilamchi qidirish (Binary Search)

Faqat oldindan tartiblangan (sorted) ma'lumotlar ustida ishlaydi.

def binary_search(nums, target):
    lo, hi = 0, len(nums) - 1

    while lo <= hi:
        mid = (lo + hi) // 2
        if nums[mid] == target:
            return mid
        if nums[mid] < target:
            lo = mid + 1
        else:
            hi = mid - 1

    return -1

sorted_nums = [1, 3, 5, 7, 9]
print(binary_search(sorted_nums, 7))  # 3
print(binary_search(sorted_nums, 4))  # -1

Ikkilamchi qidirish variantlari