線性搜索算法 Go

說(shuō)明

線性搜索是指從數(shù)組0下標(biāo)開(kāi)始荚守,依次序搜索對(duì)比的搜索方式珍德。

代碼

package arithmetic

import (
    "math"
)

//SearchLinearRtFirst 線性搜索返回第一個(gè)結(jié)果 面向算法
func SearchLinearRtFirst(element interface{}, slice []interface{},
    funcCondition func(interface{}, interface{}) bool) (int, bool) {

    for i, v := range slice {
        if funcCondition(v, element) {
            return i, true
        }
    }

    return len(slice), false
}

//InterfaceSearch 搜索接口
type InterfaceSearch interface {
    Len() int
    Condition(i int, element interface{}) bool
    GetElement(i int) interface{}
}

//SearchLinearRtFirstOop 線性搜索返回第一個(gè)結(jié)果 面向?qū)ο?func SearchLinearRtFirstOop(element interface{}, slice InterfaceSearch) (int, bool) {
    for i := 0; i < slice.Len(); i++ {
        if slice.Condition(i, element) {
            return i, true
        }
    }
    return slice.Len(), false
}

代碼說(shuō)明

面向算法:線性遍歷數(shù)組练般,通過(guò)閉包傳入的判斷條件判斷兩個(gè)元素是否相等,若相等返回元素所在數(shù)組下標(biāo)锈候,以及true 薄料。若未搜索到數(shù)據(jù)則返回?cái)?shù)組長(zhǎng)度,以及false泵琳。

面向?qū)ο螅航Y(jié)構(gòu)體通過(guò)實(shí)現(xiàn)接口摄职,取代原本閉包傳入的方式。

兩種方式各有優(yōu)缺點(diǎn)获列。主要在調(diào)用時(shí)谷市,面向算法因?yàn)镚o語(yǔ)言的特性問(wèn)題,需要將結(jié)構(gòu)數(shù)組轉(zhuǎn)換成通用的[]interface{}击孩,此部分比較耗時(shí)迫悠。兩種代碼實(shí)現(xiàn)方式都可用于自身結(jié)構(gòu)數(shù)組。其他編程語(yǔ)言情況有所不同巩梢。具體調(diào)用方式見(jiàn)下文及皂。

測(cè)試代碼

package main

import (
    "AZframework/arithmetic"
    "fmt"
)

//IntSlice []int
type IntSlice []int
//Len 搜索對(duì)比接口
func (s IntSlice) Len() int           { return len(s) }
//Condition 搜索對(duì)比接口
func (s IntSlice) Condition(i int, element interface{}) bool {
    if s[i] == element.(int) {
        return true
    }
    return false
}
//GetElement 搜索對(duì)比接口
func (s IntSlice) GetElement(i int) interface{} { return s[i] }

func main() {
    var intB = 1
    var sliceC = IntSlice{2, 3, 1, 4, 1}
    //數(shù)組轉(zhuǎn)換
    var interSlice = make([]interface{}, len(sliceC))
    for i, d := range sliceC {
        interSlice[i] = d
    }

    var x, y = arithmetic.SearchLinearRtFirst(intB, interSlice, func(a interface{}, b interface{}) bool {
        if a == b {
            return true
        }
        return false
    })
    fmt.Printf("SearchLinearRtFirst %t %d\n", y, x)

    var x2, y2 = arithmetic.SearchLinearRtFirstOop(intB, sliceC)
    fmt.Printf("SearchLinearRtFirstOop %t %d\n", y2, x2)
}

日志輸出

SearchLinearRtFirst true 2
SearchLinearRtFirstOop true 2

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市且改,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌板驳,老刑警劉巖又跛,帶你破解...
    沈念sama閱讀 217,907評(píng)論 6 506
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異若治,居然都是意外死亡慨蓝,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,987評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門端幼,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)礼烈,“玉大人,你說(shuō)我怎么就攤上這事婆跑〈税荆” “怎么了?”我有些...
    開(kāi)封第一講書(shū)人閱讀 164,298評(píng)論 0 354
  • 文/不壞的土叔 我叫張陵滑进,是天一觀的道長(zhǎng)犀忱。 經(jīng)常有香客問(wèn)我,道長(zhǎng)扶关,這世上最難降的妖魔是什么阴汇? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 58,586評(píng)論 1 293
  • 正文 為了忘掉前任,我火速辦了婚禮节槐,結(jié)果婚禮上搀庶,老公的妹妹穿的比我還像新娘拐纱。我一直安慰自己,他們只是感情好哥倔,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,633評(píng)論 6 392
  • 文/花漫 我一把揭開(kāi)白布秸架。 她就那樣靜靜地躺著,像睡著了一般未斑。 火紅的嫁衣襯著肌膚如雪咕宿。 梳的紋絲不亂的頭發(fā)上,一...
    開(kāi)封第一講書(shū)人閱讀 51,488評(píng)論 1 302
  • 那天蜡秽,我揣著相機(jī)與錄音府阀,去河邊找鬼。 笑死芽突,一個(gè)胖子當(dāng)著我的面吹牛试浙,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播寞蚌,決...
    沈念sama閱讀 40,275評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼田巴,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了挟秤?” 一聲冷哼從身側(cè)響起壹哺,我...
    開(kāi)封第一講書(shū)人閱讀 39,176評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎艘刚,沒(méi)想到半個(gè)月后管宵,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,619評(píng)論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,819評(píng)論 3 336
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了虫给。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片鹿寻。...
    茶點(diǎn)故事閱讀 39,932評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤埠居,帶...
    沈念sama閱讀 35,655評(píng)論 5 346
  • 正文 年R本政府宣布,位于F島的核電站鲸拥,受9級(jí)特大地震影響拐格,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜刑赶,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,265評(píng)論 3 329
  • 文/蒙蒙 一捏浊、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧撞叨,春花似錦金踪、人聲如沸浊洞。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 31,871評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)法希。三九已至,卻和暖如春靶瘸,著一層夾襖步出監(jiān)牢的瞬間苫亦,已是汗流浹背。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 32,994評(píng)論 1 269
  • 我被黑心中介騙來(lái)泰國(guó)打工怨咪, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留屋剑,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 48,095評(píng)論 3 370
  • 正文 我出身青樓诗眨,卻偏偏與公主長(zhǎng)得像唉匾,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子匠楚,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,884評(píng)論 2 354

推薦閱讀更多精彩內(nèi)容

  • 第2章 基本語(yǔ)法 2.1 概述 基本句法和變量 語(yǔ)句 JavaScript程序的執(zhí)行單位為行(line)巍膘,也就是一...
    悟名先生閱讀 4,149評(píng)論 0 13
  • 這是16年5月份編輯的一份比較雜亂適合自己觀看的學(xué)習(xí)記錄文檔,今天18年5月份再次想寫(xiě)文章芋簿,發(fā)現(xiàn)簡(jiǎn)書(shū)還為我保存起的...
    Jenaral閱讀 2,756評(píng)論 2 9
  • 早晨七點(diǎn)鐘的陽(yáng)光与斤,已經(jīng)很久沒(méi)見(jiàn)過(guò)逮诲。不是透過(guò)百葉窗或落地窗星星點(diǎn)點(diǎn)灑落進(jìn)房間的那種,而是一覽無(wú)余鋪滿整片草坪上的幽告。 ...
    格蕾絲姐閱讀 1,086評(píng)論 12 11
  • 我伴隨著人生中第一次哭泣來(lái)到了這個(gè)美好的世界,那一刻的哭聲代表著我對(duì)這個(gè)世界的新奇亦陌生裆甩。慢慢的一陣陣歡聲笑語(yǔ)在耳...
    穎穎LSLY閱讀 537評(píng)論 1 1
  • 我所到過(guò)的江南 雖無(wú)想象中的青石板路和小橋流水 以及那種古樸與滄桑 但卻有種水鄉(xiāng)所特有的溫婉與靈動(dòng)的氣息 柔婉動(dòng)人...
    孤獨(dú)風(fēng)影閱讀 389評(píng)論 0 3