主頁 >  其他 > 【技識訓累】演算法中的貪心演算法【一】

【技識訓累】演算法中的貪心演算法【一】

2023-06-09 08:01:17 其他

貪心演算法是什么

貪心演算法是一種常見的演算法思想,主要應用于優化問題中,特別是在計算機科學和運籌學領域中,貪心演算法的核心思想是每一步都選擇當前最好的選項,從而得到全域最優解,

貪心演算法通常包括以下步驟:

  1. 確定問題的最優子結構:即在問題中尋找那些可以自行解決的子問題,

  2. 開始構建解決方案:從問題的初始狀態開始,按照某種規則選擇一個最優解,并將其添加到中間方案中,該步驟不斷重復,直到找到全域最優解,

  3. 判斷可行性:為了確保得到一個全域最優解,需要在每個構建解決方案的步驟中,檢查得到的區域最優解是否是可行的,如果當前的區域最優解無法滿足問題的限制條件,則需要放棄此區域最優解,重新開始構建方案,

貪心演算法的優點是輸入資料越大,運行時間越短;同時,由于貪心演算法的設計都是區域的最優決策,不是全域的最優決策,因此可能不會得到最優解,但通常會得到接近最優解的解決方案,

貪心演算法適用于一些特殊的演算法場景,如圖論中的最小生成樹演算法、哈夫曼編碼等,同時,在一些工業設計、物流計劃及經濟學領域中也有應用,

貪心演算法需要注意的問題是不能保證一定得到全域最優解,有可能會導致次優解的出現,因此,在具體應用中,需要充分了解問題的性質,深入分析問題才能設計出較好的貪心演算法,

旅行商問題

一個旅行商要拜訪n個城市,求他走的最短路徑,

解題思路:

  1. 隨意選擇一個城市作為起點
  2. 從該城市出發,依次經過還未訪問的最近的城市
  3. 計算路徑長度,并記錄已訪問的城市
  4. 重復步驟2-3,直到所有城市都被訪問
  5. 回傳起點城市,路徑長度即為最短路徑
// cities為城市數量,dist為城市間距離矩陣
function TSP (cities, dist)
    visited = [false] * cities // 初始化所有城市未被訪問
    current_city = 0 // 從城市0開始
    visited[current_city] = true // 標記當前城市為已訪問
    path = [current_city] // 記錄遍歷路徑
    total_distance = 0 // 路徑總距離
    while true:
        if len(path) == cities: // 若所有城市都已訪問過,則回傳起點城市并計算路徑總距離
            total_distance += dist[current_city][0] // 加上最后一個城市到起點城市的距離
            path.append(0)
            return path, total_distance
        next_city = -1 // 下一個要訪問的城市
        min_distance = Inf // 到下一個城市路徑的最小距離
        for i in range(cities):
            if not visited[i] and dist[current_city][i] < min_distance:
                next_city = i
                min_distance = dist[current_city][i]
        current_city = next_city // 更新當前城市
        visited[current_city] = true // 標記新城市為已訪問
        path.append(current_city) // 記錄經過的城市
        total_distance += min_distance // 累計最小距離

部分背包問題

有n個物品和一個容量為C的背包,每個物品都有自己的價值和重量,求裝入背包的物品的最大價值,

1.計算每個物品的性價比(價值/重量),

2.將物品按性價比從高到低排序,

3.從性價比最高的物品開始,依次放入背包,直到背包裝滿或所有物品都放入背包,

function fractional_knapsack(n, item, C)
// n表示物品數量,item為物品陣列,C為背包容量
for i from 1 to n do
item[i].ratio = item[i].value / item[i].weight
// 計算每個物品的性價比


sort item by decreasing ratio
// 將物品按性價比從高到低排序

total_value = https://www.cnblogs.com/yyyyfly1/archive/2023/06/08/0
for i from 1 to n do
    if C >= item[i].weight then
        total_value += item[i].value
        C -= item[i].weight
        // 如果背包容量可以放下物品i,則將物品i完全放入背包
    else
        total_value += C * item[i].ratio
        break
        // 否則將物品i按比例分割,在背包中放入一部分
        // 直到背包裝滿或物品i全部放入

return total_value
// 回傳裝入背包的物品的最大價值

區間調度問題

給定n個區間,求用盡可能少的區間覆寫整個區間的最大數量,

  1. 首先按照區間結束時間的順序將所有區間排序(從小到大),設排序后的區間序列為intervals,
  2. 初始化變數end為區間intervals[0]的結束時間,計數器count為1,表示第一個區間一定要選,
  3. 遍歷排序后的區間序列intervals,如果當前區間的開始時間大于等于end,則選擇該區間,將end更新為該區間的結束時間,計數器count加1,
  4. 最后輸出計數器count即為最大數量,
sort(intervals) // 對區間按照結束時間進行排序
end = intervals[0].end // 初始化end為第一個區間的結束時間
count = 1 // 初始化計數器count為1
for i in range(1, intervals.size()):
if intervals[i].start >= end:
count += 1
end = intervals[i].end
print(count) // 輸出最大數量

最小罰款問題

某市道路有n個路口需要維修,第i個路口在時間ti - li到ti + li之間維修,若在該時段經過會被罰款wi,求如何安排維修時間,使得罰款總額最小,

  1. 將每個路口按照維修起始時間遞增排序
  2. 遍歷所有路口,維護一個區間集合,表示當前需要維修的路口時間段
  3. 對于每個路口,如果它的維修時間段與當前區間集合存在交集,則將交集部分取出,并且計算該部分的罰款總額
  4. 將該路口的維修時間段加入當前區間集合,維護集合的增序,重復步驟3,直至處理完所有路口
# 將每個路口按照維修起始時間遞增排序
sorted_intervals = sorted(intervals, key=lambda x: x[0])

# 初始:空集合 s,罰款總額 total = 0
s = set()
total = 0

# 遍歷所有路口
for interval in sorted_intervals:
    # 維修時間段 [ti-li, ti+li] 表示為區間 [l,r]
    l, r, w = interval

    # 逐個處理當前區間集合中的所有區間
    remove_intervals = set()
    for i in s:
        # 計算 區間 interval 與 i 的交集
        a, b = max(l, i[0]), min(r, i[1])
        if a <= b:
            # 將交集 [a,b] 內的路口從集合 s 中洗掉
            remove_intervals.add(i)
            # 將交集內的罰款總額加入 total
            total += w * (b - a + 1)

    # 從集合 s 中洗掉所有交集區間
    s -= remove_intervals
    # 將區間 [l,r] 加入集合 s
    s.add((l, r))

# 對于集合 s 中所有區間,以左端點為第一關鍵字,右端點為第二關鍵字進行排序
s = sorted(s, key=lambda x: (x[0], x[1]))

# 回傳罰款總額
return total

跳躍游戲

給定一個陣列,陣列中的每個元素代表你在該位置可以跳躍的最大長度,求是否可以到達最后一個元素,

  1. 記錄一個變數max_reach表示當前所能到達的最遠距離,初始值為第一個元素的距離,

  2. 對陣列從第二個元素開始遍歷: a. 如果當前位置超出了max_reach的范圍,則說明無法到達最后一個元素,回傳false, b. 否則,將當前位置能到達的最遠距離和max_reach取最大值,更新max_reach,

  3. 遍歷結束后,如果max_reach能夠到達最后一個元素,則回傳true;否則,回傳false,

function canJump(nums) {
    let max_reach = nums[0];
    for (let i = 1; i < nums.length; i++) {
        if (i > max_reach) {
            return false;
        }
        max_reach = Math.max(max_reach, i + nums[i]);
    }
    return max_reach >= nums.length - 1;
}

化學物質混合問題

有n種化學物質,需要混合制成一種新的化學物質,各種化學物質有自己的份量和價格,求最小的制作成本,

  1. 首先將各種化學物質按價格從小到大排序,

  2. 然后從價格最低的化學物質開始,依次按其份量的比例將其混合到目標物質中,

  3. 如果已混入的各種化學物質份量之和等于目標物質的總份量,則制作完成;否則繼續將價格次低的化學物質混入,

  4. 直到制作完成或者所有化學物質都已混入為止,

// 輸入:
// chemicals: 化學物質陣列,包括每種物質的份量和價格
// target_amount: 目標物質的總份量
// 注:代碼中的by_price為排序關鍵字,需要根據具體實作進行定義,


function mixedChemicals(chemicals[], target_amount):
  // 按價格從小到大排序
  sort(chemicals, by_price)

  i = 0 // 當前混入的化學物質下標
  total = 0 // 已混入的各種化學物質總份量之和
  cost = 0 // 制作成本

  // 按比例依次混入各種化學物質
  while (total < target_amount) and (i < len(chemicals)):
    // 每次混入化學物質的份量
    amount = min(target_amount - total, chemicals[i].amount)
    // 每次混入的成本
    unit_cost = chemicals[i].price / chemicals[i].amount
    // 更新總成本
    cost += amount * unit_cost
    // 更新已混入的總份量
    total += amount
    // 更新當前混入的化學物質下標
    i += 1

  // 判斷是否制作成功
  if total == target_amount:
    return cost
  else:
    return '制作失敗'

資源分配問題

  1. 給定n個資源和m個任務,每個任務需要一定量的資源,其中一些任務是必須完成的,如何分配資源使得完成必須任務的代價最小,
  2. 將所有任務按是否為必須任務分成兩組:必須完成的任務和非必須任務,
  3. 對必須完成的任務按照所需資源從大到小排序,
  4. 從資源數最大的必須任務開始,依次分配資源,直到分配完畢或無法完成必須任務,
  5. 對剩余的非必須任務按照所需資源從大到小排序,
  6. 依次給非必須任務分配資源,直到分配完畢或無法完成任務,
//將所有任務按是否為必須任務分成兩組:必須完成的任務和非必須任務,
for each task:
if task is mandatory:
add task to mandatory_tasks
else:
add task to optional_tasks



//對必須完成的任務按照所需資源從大到小排序,
sort(mandatory_tasks, by resource needed, descending)



//從資源數最大的必須任務開始,依次分配資源,直到分配完畢或無法完成必須任務,
for each task in mandatory_tasks:
if task can be completed:
allocate resources to task
else:
break



//對剩余的非必須任務按照所需資源從大到小排序,
sort(optional_tasks, by resource needed, descending)



//依次給非必須任務分配資源,直到分配完畢或無法完成任務,
for each task in optional_tasks:
if task can be completed:
allocate resources to task
else:
break

 

在黑夜里夢想著光,心中覆寫悲傷,在悲傷里忍受孤獨,空守一絲溫暖, 我的淚水是無底深海,對你的愛已無言,相信無盡的力量,那是真愛永在, 我的信仰是無底深海,澎湃著心中火焰,燃燒無盡的力量,那是忠誠永在,

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

標籤:其他

上一篇:7.1 套接字(socket)

下一篇:返回列表

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

熱門瀏覽
  • 網閘典型架構簡述

    網閘架構一般分為兩種:三主機的三系統架構網閘和雙主機的2+1架構網閘。 三主機架構分別為內端機、外端機和仲裁機。三機無論從軟體和硬體上均各自獨立。首先從硬體上來看,三機都用各自獨立的主板、記憶體及存盤設備。從軟體上來看,三機有各自獨立的作業系統。這樣能達到完全的三機獨立。對于“2+1”系統,“2”分為 ......

    uj5u.com 2020-09-10 02:00:44 more
  • 如何從xshell上傳檔案到centos linux虛擬機里

    如何從xshell上傳檔案到centos linux虛擬機里及:虛擬機CentOs下執行 yum -y install lrzsz命令,出現錯誤:鏡像無法找到軟體包 前言 一、安裝lrzsz步驟 二、上傳檔案 三、遇到的問題及解決方案 總結 前言 提示:其實很簡單,往虛擬機上安裝一個上傳檔案的工具 ......

    uj5u.com 2020-09-10 02:00:47 more
  • 一、SQLMAP入門

    一、SQLMAP入門 1、判斷是否存在注入 sqlmap.py -u 網址/id=1 id=1不可缺少。當注入點后面的引數大于兩個時。需要加雙引號, sqlmap.py -u "網址/id=1&uid=1" 2、判斷文本中的請求是否存在注入 從文本中加載http請求,SQLMAP可以從一個文本檔案中 ......

    uj5u.com 2020-09-10 02:00:50 more
  • Metasploit 簡單使用教程

    metasploit 簡單使用教程 浩先生, 2020-08-28 16:18:25 分類專欄: kail 網路安全 linux 文章標簽: linux資訊安全 編輯 著作權 metasploit 使用教程 前言 一、Metasploit是什么? 二、準備作業 三、具體步驟 前言 Msfconsole ......

    uj5u.com 2020-09-10 02:00:53 more
  • 游戲逆向之驅動層與用戶層通訊

    驅動層代碼: #pragma once #include <ntifs.h> #define add_code CTL_CODE(FILE_DEVICE_UNKNOWN,0x800,METHOD_BUFFERED,FILE_ANY_ACCESS) /* 更多游戲逆向視頻www.yxfzedu.com ......

    uj5u.com 2020-09-10 02:00:56 more
  • 北斗電力時鐘(北斗授時服務器)讓網路資料更精準

    北斗電力時鐘(北斗授時服務器)讓網路資料更精準 北斗電力時鐘(北斗授時服務器)讓網路資料更精準 京準電子科技官微——ahjzsz 近幾年,資訊技術的得了快速發展,互聯網在逐漸普及,其在人們生活和生產中都得到了廣泛應用,并且取得了不錯的應用效果。計算機網路資訊在電力系統中的應用,一方面使電力系統的運行 ......

    uj5u.com 2020-09-10 02:01:03 more
  • 【CTF】CTFHub 技能樹 彩蛋 writeup

    ?碎碎念 CTFHub:https://www.ctfhub.com/ 筆者入門CTF時時剛開始刷的是bugku的舊平臺,后來才有了CTFHub。 感覺不論是網頁UI設計,還是題目質量,賽事跟蹤,工具軟體都做得很不錯。 而且因為獨到的金幣制度的確讓人有一種想去刷題賺金幣的感覺。 個人還是非常喜歡這個 ......

    uj5u.com 2020-09-10 02:04:05 more
  • 02windows基礎操作

    我學到了一下幾點 Windows系統目錄結構與滲透的作用 常見Windows的服務詳解 Windows埠詳解 常用的Windows注冊表詳解 hacker DOS命令詳解(net user / type /md /rd/ dir /cd /net use copy、批處理 等) 利用dos命令制作 ......

    uj5u.com 2020-09-10 02:04:18 more
  • 03.Linux基礎操作

    我學到了以下幾點 01Linux系統介紹02系統安裝,密碼啊破解03Linux常用命令04LAMP 01LINUX windows: win03 8 12 16 19 配置不繁瑣 Linux:redhat,centos(紅帽社區版),Ubuntu server,suse unix:金融機構,證券,銀 ......

    uj5u.com 2020-09-10 02:04:30 more
  • 05HTML

    01HTML介紹 02頭部標簽講解03基礎標簽講解04表單標簽講解 HTML前段語言 js1.了解代碼2.根據代碼 懂得挖掘漏洞 (POST注入/XSS漏洞上傳)3.黑帽seo 白帽seo 客戶網站被黑帽植入劫持代碼如何處理4.熟悉html表單 <html><head><title>TDK標題,描述 ......

    uj5u.com 2020-09-10 02:04:36 more
最新发布
  • 【技識訓累】演算法中的貪心演算法【一】

    博客推行版本更新,成果積累制度,已經寫過的博客還會再次更新,不斷地琢磨,高質量高數量都是要追求的,工匠精神是學習必不可少的精神。因此,大家有何建議歡迎在評論區踴躍發言,你們的支持是我最大的動力,你們敢投,我就敢肝 ......

    uj5u.com 2023-06-09 08:01:17 more
  • 7.1 套接字(socket)

    套接字(socket)是計算機之間進行通信的一種技術,它允許不同主機上的行程之間進行資料交換。在Python中,我們可以使用`socket`模塊來創建和使用套接字。 首先,我們需要匯入`socket`模塊: ```python import socket ``` 在網路編程中,有兩種主要型別的套接字 ......

    uj5u.com 2023-06-09 08:01:11 more
  • 國企真的這么香嗎?軟體測驗工程師國企真物體驗:“每天過的像打仗一

    還記得,之前一名在國企上班的程式員在匿名社區發了一個帖子,瞬間爆了。
    帖子中的這位程式員表示,他在的國企,稅前工資25萬,一周實際作業時間5個小時,一個一萬行代碼的專案,寫了一年。平時上班,除了早晨做做樣子看專案計劃,一整天都在逛論壇搞副業等等…
    中午睡到兩點下午五點半走人,沒有kpi壓力,工會還時... ......

    uj5u.com 2023-06-09 08:00:58 more
  • 網路傳輸中的重要引數(1)

    # 網路傳輸中的重要引數(1) 目前從事于音視頻流媒體領域的我,主要作業在傳輸層與應用層的交界處,研究如何針對流媒體場景實作高效而可靠的傳輸協議。作業兩年比較深刻的體會之一就是網路傳輸是個看似簡單清晰實則到處是坑的領域,本系列將首先對網路傳輸中重要的幾個引數進行梳理,討論各個引數的實際意義,以及各自 ......

    uj5u.com 2023-06-09 08:00:51 more
  • k8s~RKE的方式升級Rancher集群

    # kubectl安裝 在主機或者遠程訪問的筆記本上安裝kubectl命令列工具 rancher-cluster.yml(RKE組態檔) 通過RKE創建kubernetes集群,需要預先設定rancher-cluster.yml組態檔,通過這個組態檔安裝kubernetes集群,同時可以指定 ......

    uj5u.com 2023-06-09 08:00:44 more
  • 【技識訓累】演算法中的動態規劃【一】

    博客推行版本更新,成果積累制度,已經寫過的博客還會再次更新,不斷地琢磨,高質量高數量都是要追求的,工匠精神是學習必不可少的精神。因此,大家有何建議歡迎在評論區踴躍發言,你們的支持是我最大的動力,你們敢投,我就敢肝 ......

    uj5u.com 2023-06-09 08:00:36 more
  • 10.1. Java性能調優

    Java性能調優是一個復雜且重要的主題,它涉及到了JVM、垃圾收集器、記憶體管理、多執行緒、代碼優化等多個方面。在本節中,我們將對Java性能調優的基本概念和方法進行簡要介紹。 #### 10.1.1. 理解性能指標 在進行性能調優之前,我們首先需要了解主要的性能指標。以下是一些常見的性能指標: 1. ......

    uj5u.com 2023-06-09 08:00:30 more
  • EndNote參考文獻格式Output Styles界面介紹

    本文對**EndNote**軟體修改論文參考文獻**參考格式**的界面與各選項引數加以詳細介紹。 利用**EndNote**軟體進行論文參考文獻的插入可以說是非常方便;但其亦具有一個問題,就是對中文文獻的支持不太友好;之前也用過**NoteExpress**,這一國產軟體對于中文參考文獻的支持性很好 ......

    uj5u.com 2023-06-09 07:59:53 more
  • 現在公司都不缺人了?軟體測驗作業經歷3年,居然被坑了?防不勝防!

    大概介紹一下個人情況,女,本科,三年多測驗作業經驗,懂python,會寫腳本,會selenium,會性能,然而到今天都沒有收到一份offer!從年后就開始準備簡歷,年后上班的第一天就開始投,開始只是投了一些官網已久的崗位,并沒有收到面試邀請,得到的都是不匹配的反饋,一度懷疑是不是簡歷寫的不好,后來大... ......

    uj5u.com 2023-06-09 07:59:21 more
  • 代碼自動生成,給程式員帶來的是“春天”還是“寒冬”?

    **[CodeGeeX](https://codegeex.cn/)**受邀參與由AI大模型領域的青年中堅力量組織的思辨活動。在計算機編程領域,基于大模型能力的代碼生成工具,探討給程式員帶來的各種機會與挑戰。近期**[CodeGeeX](https://codegeex.cn/)** 2.0大版本上 ......

    uj5u.com 2023-06-09 07:59:09 more