mirror of
https://github.com/krahets/hello-algo.git
synced 2025-11-03 05:27:55 +08:00
[Rust] Normalize mid calculation in case overflow (#1363)
* Normalize mid calculate in case overflow * Change ALL language * Update merge_sort.py * Update merge_sort.zig * Update binary_search_tree.zig * Update binary_search_recur.py --------- Co-authored-by: Yudong Jin <krahets@163.com>
This commit is contained in:
@ -19,7 +19,7 @@ fun merge(nums: IntArray, left: Int, mid: Int, right: Int) {
|
||||
while (i <= mid && j <= right) {
|
||||
if (nums[i] <= nums[j])
|
||||
tmp[k++] = nums[i++]
|
||||
else
|
||||
else
|
||||
tmp[k++] = nums[j++]
|
||||
}
|
||||
// 將左子陣列和右子陣列的剩餘元素複製到臨時陣列中
|
||||
@ -40,7 +40,7 @@ fun mergeSort(nums: IntArray, left: Int, right: Int) {
|
||||
// 終止條件
|
||||
if (left >= right) return // 當子陣列長度為 1 時終止遞迴
|
||||
// 劃分階段
|
||||
val mid = (left + right) / 2 // 計算中點
|
||||
val mid = left + (right - left) / 2 // 計算中點
|
||||
mergeSort(nums, left, mid) // 遞迴左子陣列
|
||||
mergeSort(nums, mid + 1, right) // 遞迴右子陣列
|
||||
// 合併階段
|
||||
@ -53,4 +53,4 @@ fun main() {
|
||||
val nums = intArrayOf(7, 3, 2, 6, 0, 1, 5, 4)
|
||||
mergeSort(nums, 0, nums.size - 1)
|
||||
println("合併排序完成後 nums = ${nums.contentToString()}")
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user