主頁 > 後端開發 > 演算法 in Go:Binary Search(二分查找)

演算法 in Go:Binary Search(二分查找)

2023-06-06 08:54:03 後端開發

演算法 in Go:Binary Search(二分查找)

Binary Search(二分查找)

Binary Search(二分查找)

  • 猜數
  • 1、2、3、4、5、6、7、8
  • 排好序一個集合,先從中間開始猜,根據提示就可以排除一半,在剩余的一半里,再從中間開始猜,依此類推,這就是二分查找,

Binary Search(二分查找)接收什么引數,回傳什么值

  • 輸入:排好序的集合
  • 如果要查找的元素在集合中:回傳位置(索引)
  • 否則:回傳空

Binary Search(二分查找)其它查找方式

  • 如果查找?
  • [1,2,3,4,5,...56,57,58...98,99,100]
  • 順序的簡單查找(simple search)
  • 更好的辦法:從中間開始,每次都能排除一半的元素,這叫二分查找
  • [1,2,3,4,5...98,99.100],查找任何一個元素,最多只需要7步
  • [1,2,3,4,5...239998,239999,240000]
    • 二分查找,最多只需要 18步
    • 簡單查找,最多需要 24 萬步
  • 針對擁有 n 哥元素的已排序集合:
    • 二分查找:log2^n
    • 簡單查找:n

注意

  • 二分查找只適用于已排序的集合

創建專案

~/Code/go via ?? v1.20.3 via ?? base
? mcd algorithms_binary_search

Code/go/algorithms_binary_search via ?? v1.20.3 via ?? base
? go mod init algorithms_binary_search
go: creating new go.mod: module algorithms_binary_search

Code/go/algorithms_binary_search via ?? v1.20.3 via ?? base
? c

Code/go/algorithms_binary_search via ?? v1.20.3 via ?? base
?

實作演算法程序中的問題

問題:

這段代碼r := rand.New(rand.NewSource(time.Now().UnixNano())) v := r.Intn(10)和這段代碼: v := rand.Intn(10)有什么區別?

ChatGPT解答:

這兩段代碼的區別在于亂數生成器的種子(seed),

在第一段代碼中,我們使用了 rand.NewSource(time.Now().UnixNano()) 作為種子,創建了一個新的亂數生成器 rtime.Now().UnixNano() 回傳當前時間的納秒表示,作為種子值,通過使用不同的種子值,我們可以得到不同的亂數序列,

然后,我們使用 r.Intn(10) 從生成器 r 中生成一個介于 0 和 9 之間的隨機整數,

而在第二段代碼中,我們直接呼叫了 rand.Intn(10),這里的 rand 是 Go 語言中的標準庫 math/rand 包,它使用默認的亂數生成器,默認情況下,標準庫的亂數生成器的種子值是固定的(通常為 1),因此在相同的程式運行中多次呼叫 rand.Intn(10) 得到的亂數序列是相同的,

因此,第一段代碼使用了一個可變的種子值,每次運行程式時都會產生不同的亂數序列,而第二段代碼使用了固定的種子值,多次運行得到的亂數序列是相同的,

演算法實作:

package main

import (
	"fmt"
	"math/rand"
	"time"
)

func main() {
	list := make([]int, 1_000_000)
	for i := 0; i < 1_000_000; i++ {
		list = append(list, i+1)
	}

	// rand.Seed(time.Now().UnixNano())
	r := rand.New(rand.NewSource(time.Now().UnixNano()))
	for i := 0; i < 20; i++ {
		v := r.Intn(1_000_000-1) + 1
		fmt.Printf("針對 %d 進行二分查找:\n", v)
		idx := binarySearch(list, v)
		fmt.Printf("%d 的索引位置是:[%d]\n", v, idx)
		fmt.Println("_____________________________")
	}
}

func binarySearch(list []int, target int) int {
	low := 0
	high := len(list) - 1

	step := 0
	for {
		step = step + 1
		if low <= high {
			mid := (low + high) / 2
			guess := list[mid]
			if guess == target {
				fmt.Printf("共查找了 %d 次\n", step)
				return mid
			}
			if guess > target {
				high = mid - 1
			} else {
				low = mid + 1
			}
		}
	}
}

運行

Code/go/algorithms_binary_search via ?? v1.20.3 via ?? base 
? go run .
針對 518758 進行二分查找:
共查找了 21 次
518758 的索引位置是:[1518757]
_____________________________
針對 13067 進行二分查找:
共查找了 18 次
13067 的索引位置是:[1013066]
_____________________________
針對 186102 進行二分查找:
共查找了 18 次
186102 的索引位置是:[1186101]
_____________________________
針對 606006 進行二分查找:
共查找了 21 次
606006 的索引位置是:[1606005]
_____________________________
針對 806929 進行二分查找:
共查找了 17 次
806929 的索引位置是:[1806928]
_____________________________
針對 938525 進行二分查找:
共查找了 19 次
938525 的索引位置是:[1938524]
_____________________________
針對 718792 進行二分查找:
共查找了 21 次
718792 的索引位置是:[1718791]
_____________________________
針對 583982 進行二分查找:
共查找了 20 次
583982 的索引位置是:[1583981]
_____________________________
針對 569047 進行二分查找:
共查找了 21 次
569047 的索引位置是:[1569046]
_____________________________
針對 450770 進行二分查找:
共查找了 21 次
450770 的索引位置是:[1450769]
_____________________________
針對 503611 進行二分查找:
共查找了 19 次
503611 的索引位置是:[1503610]
_____________________________
針對 792959 進行二分查找:
共查找了 21 次
792959 的索引位置是:[1792958]
_____________________________
針對 663440 進行二分查找:
共查找了 21 次
663440 的索引位置是:[1663439]
_____________________________
針對 967010 進行二分查找:
共查找了 20 次
967010 的索引位置是:[1967009]
_____________________________
針對 631813 進行二分查找:
共查找了 20 次
631813 的索引位置是:[1631812]
_____________________________
針對 608258 進行二分查找:
共查找了 21 次
608258 的索引位置是:[1608257]
_____________________________
針對 494806 進行二分查找:
共查找了 21 次
494806 的索引位置是:[1494805]
_____________________________
針對 92081 進行二分查找:
共查找了 19 次
92081 的索引位置是:[1092080]
_____________________________
針對 615060 進行二分查找:
共查找了 21 次
615060 的索引位置是:[1615059]
_____________________________
針對 798577 進行二分查找:
共查找了 20 次
798577 的索引位置是:[1798576]
_____________________________

Code/go/algorithms_binary_search via ?? v1.20.3 via ?? base 
? 

思考:

log2^1_000_000 的對數大約等于19.93,所以說最多的次數應該是20次才對,為什么會有這么多21次?

因為二分查找取中間數,有可能不在正中間的位置,就有可能多出來一次,比如1 2 3 4 這個集合,

問題:log 以 2為底 100萬的對數是多少

ChatGPT 解答:

要計算以 2 為底的 100 萬的對數,可以使用對數的換底公式,

換底公式為:log_b(x) = log_c(x) / log_c(b)

在這個問題中,我們需要計算以 2 為底的 100 萬的對數,可以將其轉換為以 10 為底的對數:

log_2(1000000) = log_10(1000000) / log_10(2)

現在我們可以使用任何對數計算器或編程語言中的對數函式來計算這個運算式,在這里,我們將使用自然對數(以 e 為底)來計算它,

log_2(1000000) ≈ ln(1000000) / ln(2)

讓我計算一下:

package main

import (
	"fmt"
	"math"
)

func main() {
	result := math.Log(1000000) / math.Log(2)
	fmt.Println(result)
}

輸出結果大約為 19.931568569324174,

因此,以 2 為底的 100 萬的對數約為 19.93,

本文來自博客園,作者:QIAOPENGJUN,轉載請注明原文鏈接:https://www.cnblogs.com/QiaoPengjun/p/17459195.html

轉載請註明出處,本文鏈接:https://www.uj5u.com/houduan/554350.html

標籤:其他

上一篇:day09-SpringCloud Sleuth+Zipkin-鏈路追蹤

下一篇:返回列表

標籤雲
其他(160376) Python(38206) JavaScript(25475) Java(18198) C(15237) 區塊鏈(8269) C#(7972) AI(7469) 爪哇(7425) MySQL(7234) html(6777) 基礎類(6313) sql(6102) 熊猫(6058) PHP(5873) 数组(5741) R(5409) Linux(5346) 反应(5209) 腳本語言(PerlPython)(5129) 非技術區(4971) Android(4582) 数据框(4311) css(4259) 节点.js(4032) C語言(3288) json(3245) 列表(3129) 扑(3119) C++語言(3117) 安卓(2998) 打字稿(2995) VBA(2789) Java相關(2746) 疑難問題(2699) 细绳(2522) 單片機工控(2479) iOS(2434) ASP.NET(2403) MongoDB(2323) 麻木的(2285) 正则表达式(2254) 字典(2211) 循环(2198) 迅速(2185) 擅长(2169) 镖(2155) .NET技术(1981) 功能(1967) HtmlCss(1952) Web開發(1951) C++(1929) python-3.x(1918) 弹簧靴(1913) xml(1889) PostgreSQL(1879) .NETCore(1863) 谷歌表格(1846) Unity3D(1843) for循环(1842)

熱門瀏覽
  • 【C++】Microsoft C++、C 和匯編程式檔案

    ......

    uj5u.com 2020-09-10 00:57:23 more
  • 例外宣告

    相比于斷言適用于排除邏輯上不可能存在的狀態,例外通常是用于邏輯上可能發生的錯誤。 例外宣告 Item 1:當函式不可能拋出例外或不能接受拋出例外時,使用noexcept 理由 如果不打算拋出例外的話,程式就會認為無法處理這種錯誤,并且應當盡早終止,如此可以有效地阻止例外的傳播與擴散。 示例 //不可 ......

    uj5u.com 2020-09-10 00:57:27 more
  • Codeforces 1400E Clear the Multiset(貪心 + 分治)

    鏈接:https://codeforces.com/problemset/problem/1400/E 來源:Codeforces 思路:給你一個陣列,現在你可以進行兩種操作,操作1:將一段沒有 0 的區間進行減一的操作,操作2:將 i 位置上的元素歸零。最終問:將這個陣列的全部元素歸零后操作的最少 ......

    uj5u.com 2020-09-10 00:57:30 more
  • UVA11610 【Reverse Prime】

    本人看到此題沒有翻譯,就附帶了一個自己的翻譯版本 思考 這一題,它的第一個要求是找出所有 $7$ 位反向質數及其質因數的個數。 我們應該需要質數篩篩選1~$10^{7}$的所有數,這里就不慢慢介紹了。但是,重讀題,我們突然發現反向質數都是 $7$ 位,而將它反過來后的數字卻是 $6$ 位數,這就說明 ......

    uj5u.com 2020-09-10 00:57:36 more
  • 統計區間素數數量

    1 #pragma GCC optimize(2) 2 #include <bits/stdc++.h> 3 using namespace std; 4 bool isprime[1000000010]; 5 vector<int> prime; 6 inline int getlist(int ......

    uj5u.com 2020-09-10 00:57:47 more
  • C/C++編程筆記:C++中的 const 變數詳解,教你正確認識const用法

    1、C中的const 1、區域const變數存放在堆疊區中,會分配記憶體(也就是說可以通過地址間接修改變數的值)。測驗代碼如下: 運行結果: 2、全域const變數存放在只讀資料段(不能通過地址修改,會發生寫入錯誤), 默認為外部聯編,可以給其他源檔案使用(需要用extern關鍵字修飾) 運行結果: ......

    uj5u.com 2020-09-10 00:58:04 more
  • 【C++犯錯記錄】VS2019 MFC添加資源不懂如何修改資源宏ID

    1. 首先在資源視圖中,添加資源 2. 點擊新添加的資源,復制自動生成的ID 3. 在解決方案資源管理器中找到Resource.h檔案,編輯,使用整個專案搜索和替換的方式快速替換 宏宣告 4. Ctrl+Shift+F 全域搜索,點擊查找全部,然后逐個替換 5. 為什么使用搜索替換而不使用屬性視窗直 ......

    uj5u.com 2020-09-10 00:59:11 more
  • 【C++犯錯記錄】VS2019 MFC不懂的批量添加資源

    1. 打開資源頭檔案Resource.h,在其中預先定義好宏 ID(不清楚其實ID值應該設定多少,可以先新建一個相同的資源項,再在這個資源的ID值的基礎上遞增即可) 2. 在資源視圖中選中專案資源,按F7編輯資源檔案,按 ID 型別 相對路徑的形式添加 資源。(別忘了先把檔案拷貝到專案中的res檔案 ......

    uj5u.com 2020-09-10 01:00:19 more
  • C/C++編程筆記:關于C++的參考型別,專供新手入門使用

    今天要講的是C++中我最喜歡的一個用法——參考,也叫別名。 參考就是給一個變數名取一個變數名,方便我們間接地使用這個變數。我們可以給一個變數創建N個參考,這N + 1個變數共享了同一塊記憶體區域。(參考型別的變數會占用記憶體空間,占用的記憶體空間的大小和指標型別的大小是相同的。雖然參考是一個物件的別名,但 ......

    uj5u.com 2020-09-10 01:00:22 more
  • 【C/C++編程筆記】從頭開始學習C ++:初學者完整指南

    眾所周知,C ++的學習曲線陡峭,但是花時間學習這種語言將為您的職業帶來奇跡,并使您與其他開發人員區分開。您會更輕松地學習新語言,形成真正的解決問題的技能,并在編程的基礎上打下堅實的基礎。 C ++將幫助您養成良好的編程習慣(即清晰一致的編碼風格,在撰寫代碼時注釋代碼,并限制類內部的可見性),并且由 ......

    uj5u.com 2020-09-10 01:00:41 more
最新发布
  • 演算法 in Go:Binary Search(二分查找)

    # 演算法 in Go:Binary Search(二分查找) ## Binary Search(二分查找) ### Binary Search(二分查找) - 猜數 - 1、2、3、4、5、6、7、8 - 排好序一個集合,先從中間開始猜,根據提示就可以排除一半,在剩余的一半里,再從中間開始猜,依此類 ......

    uj5u.com 2023-06-06 08:54:03 more
  • day09-SpringCloud Sleuth+Zipkin-鏈路追蹤

    # SpringCloud Sleuth+Zipkin-鏈路追蹤 官網:[spring-cloud/spring-cloud-sleuth: Distributed tracing for spring cloud (github.com)](https://github.com/spring-cl ......

    uj5u.com 2023-06-06 08:53:40 more
  • IO流 p7 物件流-ObjectInputStream 和 ObjectOutputStream

    # 物件流ObjectInputStream和ObjectOutputStream ## 引言 - 看一個需求 1. 將int num=100這個 int 資料保存到檔案中,注意不是 100 數字,而是 int 100,并且,能夠從檔案中直接恢復 int 100; 2. 將Dog dog = new ......

    uj5u.com 2023-06-06 08:53:17 more
  • C++面試八股文:如何在堆上和堆疊上分配一塊記憶體?

    某日二師兄參加XXX科技公司的C++工程師開發崗位6面: > 面試官: 如何在堆上申請一塊記憶體? > > 二師兄:常用的方法有malloc,new等。 > > 面試官:兩者有什么區別? > > 二師兄:malloc是向作業系統申請一塊記憶體,這塊記憶體沒有經過初始化,通常需要使用memset手動初始化。 ......

    uj5u.com 2023-06-06 08:53:10 more
  • IO流 p6 BufferedInputStream 和 BufferedOutputStream

    # BufferedInputStream 和 BufferedOutputStream - BufferedInputStream ![](https://img2023.cnblogs.com/blog/3008601/202306/3008601-20230604103033021-44120 ......

    uj5u.com 2023-06-06 08:52:59 more
  • Java如何實作去重?這是在炫技嗎?

    大家好,我3y啊。由于去重邏輯重構了幾次,好多股東直呼看不懂,于是我今天再安排一波對代碼的決議吧。`austin`支持兩種去重的型別:**N分鐘相同內容達到N次**去重和**一天內N次相同渠道頻次**去重。 > **Java開源專案訊息推送平臺🔥推送下發【郵件】【短信】【微信服務號】【微信小程式】 ......

    uj5u.com 2023-06-06 08:52:51 more
  • Python生成器深度決議:構建強大的資料處理管道

    # 前言 生成器是Python的一種核心特性,允許我們在請求新元素時再生成這些元素,而不是在開始時就生成所有元素。它在處理大規模資料集、實作節省記憶體的演算法和構建復雜的迭代器模式等多種情況下都有著廣泛的應用。在本篇文章中,我們將從理論和實踐兩方面來探索Python生成器的深度用法。 ## 生成器的定義 ......

    uj5u.com 2023-06-06 08:52:32 more
  • 前后端分離架構下使用 Sa-Token 完成登錄認證

    ### 一、架構分析 目前絕大多數系統都已經采用 “前后端分離” 架構來設計了,傳統的Session模式鑒權也不再適合這種架構(或者需要額外寫很多的代碼來專門適配)。 Sa-Token 是一個 java 輕量級權限認證框架,專為前后端分離架構打造,主要解決登錄認證、權限認證、單點登錄、OAuth2、 ......

    uj5u.com 2023-06-06 08:52:28 more
  • 在B站爬取坤坤的視頻,并獲取視頻基本資訊

    在B站有許多坤坤的視頻,作為一名ikun,讓我們寫個爬蟲研究一下視頻的視頻的名字、鏈接、觀看次數、彈幕、發布時間以及作者。我們用selenium來實作這個爬蟲,由于要獲取的資料比較多,我們寫幾個函式來實作這個爬蟲。 先倒入需要用到的庫,包括selenium, time ,BeautifulSoup ......

    uj5u.com 2023-06-06 08:52:22 more
  • 完成第一個 Vue3.2 專案后,使用體會

    第一次Composition API 在vue3.2中,正式支持了script setup的寫法,這樣可以大大簡化組件的代碼量,減少一些重復操作,我認為當你寫vue3時,應該把這當作默認寫法。在vue3.2之前,一般會這樣寫。 <script> export default { setup(prop ......

    uj5u.com 2023-06-06 08:52:18 more