mirror of
https://github.com/krahets/hello-algo.git
synced 2026-07-04 11:44:21 +00:00
772183705e
* Add Russian docs site baseline * Add Russian localized codebase * Polish Russian code wording * Update ru code translation. * Update code translation and chapter covers. * Fix pythontutor extraction. * Add README and landing page. * placeholder of profiles * Use figures of English version * Remove chapter paperbook
50 lines
1.7 KiB
Go
50 lines
1.7 KiB
Go
// File: binary_search_insertion.go
|
|
// Created Time: 2023-08-23
|
|
// Author: Reanon (793584285@qq.com)
|
|
|
|
package chapter_searching
|
|
|
|
/* Бинарный поиск точки вставки (без повторяющихся элементов) */
|
|
func binarySearchInsertionSimple(nums []int, target int) int {
|
|
// Инициализировать двусторонне замкнутый интервал [0, n-1]
|
|
i, j := 0, len(nums)-1
|
|
for i <= j {
|
|
// Вычислить индекс середины m
|
|
m := i + (j-i)/2
|
|
if nums[m] < target {
|
|
// target находится в интервале [m+1, j]
|
|
i = m + 1
|
|
} else if nums[m] > target {
|
|
// target находится в интервале [i, m-1]
|
|
j = m - 1
|
|
} else {
|
|
// Найти target и вернуть точку вставки m
|
|
return m
|
|
}
|
|
}
|
|
// target не найден, вернуть точку вставки i
|
|
return i
|
|
}
|
|
|
|
/* Бинарный поиск точки вставки (с повторяющимися элементами) */
|
|
func binarySearchInsertion(nums []int, target int) int {
|
|
// Инициализировать двусторонне замкнутый интервал [0, n-1]
|
|
i, j := 0, len(nums)-1
|
|
for i <= j {
|
|
// Вычислить индекс середины m
|
|
m := i + (j-i)/2
|
|
if nums[m] < target {
|
|
// target находится в интервале [m+1, j]
|
|
i = m + 1
|
|
} else if nums[m] > target {
|
|
// target находится в интервале [i, m-1]
|
|
j = m - 1
|
|
} else {
|
|
// Первый элемент меньше target находится в интервале [i, m-1]
|
|
j = m - 1
|
|
}
|
|
}
|
|
// Вернуть точку вставки i
|
|
return i
|
|
}
|