Files
hello-algo/ja/codes/swift/chapter_searching/binary_search_insertion.swift
Yudong Jin d7b2277d2b Re-translate the Japanese version (#1871)
* Retranslate Japanese docs with GPT-5.4

* Retranslate Japanese code with GPT-5.4
2026-03-30 07:30:15 +08:00

72 lines
2.3 KiB
Swift
Raw Permalink Blame History

This file contains ambiguous Unicode characters
This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.
/**
* File: binary_search_insertion.swift
* Created Time: 2023-08-06
* Author: nuomi1 (nuomi1@qq.com)
*/
/* */
func binarySearchInsertionSimple(nums: [Int], target: Int) -> Int {
// [0, n-1]
var i = nums.startIndex
var j = nums.endIndex - 1
while i <= j {
let m = i + (j - i) / 2 // m
if nums[m] < target {
i = m + 1 // target [m+1, j]
} else if nums[m] > target {
j = m - 1 // target [i, m-1]
} else {
return m // target m
}
}
// target i
return i
}
/* */
public func binarySearchInsertion(nums: [Int], target: Int) -> Int {
// [0, n-1]
var i = nums.startIndex
var j = nums.endIndex - 1
while i <= j {
let m = i + (j - i) / 2 // m
if nums[m] < target {
i = m + 1 // target [m+1, j]
} else if nums[m] > target {
j = m - 1 // target [i, m-1]
} else {
j = m - 1 // target [i, m-1]
}
}
// i
return i
}
#if !TARGET
@main
enum BinarySearchInsertion {
/* Driver Code */
static func main() {
//
var nums = [1, 3, 6, 8, 12, 15, 23, 26, 31, 35]
print("\n配列 nums = \(nums)")
//
for target in [6, 9] {
let index = binarySearchInsertionSimple(nums: nums, target: target)
print("要素 \(target) の挿入位置のインデックスは \(index)")
}
//
nums = [1, 3, 6, 6, 6, 6, 6, 10, 12, 15]
print("\n配列 nums = \(nums)")
//
for target in [2, 6, 20] {
let index = binarySearchInsertion(nums: nums, target: target)
print("要素 \(target) の挿入位置のインデックスは \(index)")
}
}
}
#endif