久久久久久久999_99精品久久精品一区二区爱城_成人欧美一区二区三区在线播放_国产精品日本一区二区不卡视频_国产午夜视频_欧美精品在线观看免费

 找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

搜索
查看: 2481|回復(fù): 0
收起左側(cè)

回溯搜索算法的程序

[復(fù)制鏈接]
ID:127496 發(fā)表于 2016-6-20 23:12 | 顯示全部樓層 |閱讀模式
    回溯搜索這種算法那是相當(dāng)?shù)挠杏茫覍τ诔鯇W(xué)者來說還很簡單。學(xué)習(xí)它的前提是你必須先理解一下遞歸是怎么回事。。如果不知道你可以上百度搜一搜或是在空間里找到關(guān)于我寫的遞歸的那篇文章。。如果已經(jīng)理解了遞歸那么理解回溯搜索就是一件很簡單的事了。


    回溯是怎么回事呢?說簡單了就是“一條路搜到黑”,當(dāng)無法再繼續(xù)搜下去時我就返回上一步。有點(diǎn)像左手法則,總是最終的結(jié)果就是會從左到右的(或從右到左)遍歷整個樹(即遍歷所有情況)。



    那么,既然是說明算法那么總得舉幾個例子來看看吧。這里有一道“經(jīng)典”的題目:

        

        輸入一個長度=15的字符串(此處示范為"342589062876256"),在其中插入5個“+”號,盡量使得最終結(jié)果最小。該怎么寫呢?


    這里使用VBScript做一個示范吧:
Dim ax, ex
ax=10^10
ex=""
Function Rec (Str1, InsertAt, Plus_N)
    '注釋:Str1:當(dāng)前字符串。InsertAt:當(dāng)前指針的位置。Plus_N:剩余的加號數(shù)量

    Dim a, StrA, StrB, StrC
    If InsertAt = Len(Str1) Then '如果搜索到了字符串的末尾
        If Plus_N = 0 Then '如果剩余加號數(shù)量為0,(而不是負(fù)數(shù)或正數(shù))
            a = Eval(Str1) '計(jì)算結(jié)果值            if a<ax Then   '如果小于“最優(yōu)值”                ax = a     '儲存他
                ex = Str1
            End If
        Else
            Exit Function
        End If
    Else
        StrA = Mid (Str1, 1, InsertAt)'把字符串分段
        StrB = Mid (Str1, InsertAt + 1, Len(Str1) - InsertAt)
        Rec StrA & "+" & StrB, InsertAt + 2, Plus_N - 1  '先嘗試在其中插入加號的情況
        Rec StrA & StrB, InsertAt + 1, Plus_N            '再嘗試不插入加號的情況。這樣就能遍歷所有的情況了。
    End If
End Function

Rec "342589062876256", 1, 5   '調(diào)用函數(shù)
msgbox ex & "=" & ax    '儲存結(jié)果


    當(dāng)然,你會發(fā)現(xiàn)這段代碼存在的問題也很大,有很大的優(yōu)化空間,題目要求只能插入5個加號,但有時候我們插入了更多,有時候我們一個也沒有插入。對這些情況的搜索浪費(fèi)了相當(dāng)多的時間。你可以通過加一個計(jì)數(shù)器來計(jì)算這個程序一共遍歷了多少個節(jié)點(diǎn)。而實(shí)際上有許多借點(diǎn)可以丟棄。如何來優(yōu)化它?方法就是就是剪枝。我們下一次再討論。





回復(fù)

使用道具 舉報(bào)

您需要登錄后才可以回帖 登錄 | 立即注冊

本版積分規(guī)則

小黑屋|51黑電子論壇 |51黑電子論壇6群 QQ 管理員QQ:125739409;技術(shù)交流QQ群281945664

Powered by 單片機(jī)教程網(wǎng)

快速回復(fù) 返回頂部 返回列表
主站蜘蛛池模板: 国内精品一区二区三区 | 日日操天天操 | 亚洲精品第一 | 久久久久免费视频 | 久久性色 | 免费av网址在线观看 | 国产无精乱码一区二区三区 | 国产视频在线观看视频 | 在线午夜视频 | 亚洲一区视频在线 | 国产欧美精品 | 日韩城人网站 | 亚洲免费二区 | 天堂成人av | 午夜美女福利 | 日韩在线视频免费 | 国产中文字幕一区二区 | 18视频在线观看 | 欧美日韩精品一区二区三区 | 在线观看欧美日韩 | 黄色小视频在线观看 | 一区二区三区视频 | 成人在线视频观看 | 热久久久久| 一区二区三区在线免费 | 欧美日韩精品一区二区三区 | 在线观看二区 | 色一情一乱一乱一区91av | 麻豆成人免费视频 | 80日本xxxxxxxxx96 国产成人在线免费视频 | 欧美一区二区三区在线视频 | 在线免费观看黄色片 | 国产普通话对白 | 亚洲第一伊人 | 人人爱人人插 | 91色国产 | 97av在线视频| 日韩在线观看免费 | 在线观看欧美日韩视频 | 欧美一区二区三区的 | 天天色影院|