演算法導論--平攤分析之聚集分析

来源:http://www.cnblogs.com/joey-hua/archive/2016/12/19/6196093.html
-Advertisement-
Play Games

在平攤分析中,執行一系列數據結構操作所需要的時間是通過對執行的所有操作求平均而得出的。 平攤分析可以用來證明在一系列操作中,通過對所有操作求平均之後,即使其中單一的操作具有較大的代價,平均代價還是很小的。平攤分析與平均情況分析的不同之處在於它不牽涉到概率;平攤分析保證在最壞情況下,每個操作具有平均性 ...


在平攤分析中,執行一系列數據結構操作所需要的時間是通過對執行的所有操作求平均而得出的。

平攤分析可以用來證明在一系列操作中,通過對所有操作求平均之後,即使其中單一的操作具有較大的代價,平均代價還是很小的。平攤分析與平均情況分析的不同之處在於它不牽涉到概率;平攤分析保證在最壞情況下,每個操作具有平均性能。

聚集分析

在聚集分析中,要證明對所有的n,由n個操作所構成的序列的總時間在最壞情況下為T(n)。因此,在最壞情況下,每個操作的平均代價(或稱平攤分析)為T(n)/n。請註意這個平攤代價對每個操作都是成立的,即使當序列中存在幾種類型的操作時也是一樣的。

棧操作

 在關於聚集分析的第一個例子中,我們要分析增加了一個新操作後的棧。有兩種基本的棧操作,每種操作的時間代價都是O(1):

PUSH(S,x):將對象x壓入棧S。

POP(S):彈出S的棧頂返回彈出的對象。

因為這兩個操作的運行時間都為O(1),故可以把每個操作的代價都視為1。因此,含n個PUSH和POP操作的序列的總代價為n,而這n個操作的實際運行時間就是O(n)。

現在我們增加一個棧操作MULTIPOP(S,k),它的作用是彈出棧S的k個棧頂對象,或者,當棧包含少於k個對象時,彈出整個棧中的數據對象。

當MULTIPOP(S,s)對一個包含s個對象的棧操作時,運行時間是多少?實際的運行時間與實際執行的POP操作數成線性關係,因而只要按PUSH和POP具有抽象代價1來分析MULTIPOP就足夠了。while迴圈迭代的次數是從棧中彈出的對象個數min(s,k)。對迴圈的每次迭代,都要調用一次POP。因此,MULTIPOP的總代價是min(s,k),而實際運行時間則為這個代價的一個線性函數。

現在來分析一個由n個PUSH,POP和MULTIPOP操作構成的序列,其作用於一個初始為空的棧。序列中一次MULTIPOP操作的最壞情況代價為O(n),因為棧的大小至多為n。因此,任意棧操作的最壞情況時間就是O(n),因此n個操作的序列的代價是O(n^2),因為可能會有O(n)個MULTIPOP操作,每個的代價都是O(n)。雖然這一分析是正確的,但通過單獨地考慮每個操作的最壞情況代價而得到的O(n^2)結論卻是不夠緊確的。

利用聚集分析,我們可以獲得一個考慮到n個操作的整個序列的更好的上界。事實上,雖然一次MULTIPOP操作的代價可能較高,但當作用於一個初始為空的棧上時,任意一個包含n個PUSH,POP和MULTIPOP操作的序列其代價至多為O(n)。為什麼會是這樣呢?一個對象在每次被壓入棧後,至多被彈出一次。所以,在一個非空棧上,調用POP的次數(包括在MULTIPOP的調用)至多等於PUSH操作的次數,即至多為n。對任意的n值,包含n個PUSH,POP和MULTIPOP操作的序列的總時間為O(n)。每個操作的平均代價為O(n)/n=O(1)。在聚集分析中,我們把每個操作的平攤代價指派為平均代價。所以在這個例子中,三個棧操作的平攤代價都是O(1)。

我們再一次強調,雖然已經說明一個棧操作的平均代價和運行時間是O(1),但沒有用到概率推理。實際上,我們給出的是一列n個操作的最壞情況界O(n)。用n除這個總代價可得每個操作的平均代價,亦即平攤代價。


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 多線程下載就是將同一個網路上的原始文件根據線程個數分成均等份,然後每個單獨的線程下載對應的一部分 ...
  • 概覽屏幕 概覽屏幕 概覽屏幕(也稱為最新動態屏幕、最近任務列表或最近使用的應用)是一個系統級別 UI,其中列出了最近訪問過的 Activity 和任務。 用戶可以瀏覽該列表並選擇要恢復的任務,也可以通過滑動清除任務將其從列表中移除。 對於 Android 5.0 版本(API 級別 21),包含不同 ...
  • 廣度優先搜索 在給定圖G=(V,E)和一個特定的源頂點s的情況下,廣度優先搜索系統地探索G中的邊,以期“發現”可從s 到達的所有頂點,並計算s 到所有這些可達頂點之間的距離(即最少的邊數)。該搜索演算法同時還能生成一棵根為s、且包括所有s 的可達頂點的廣度優先樹。對從s 可達的任意頂點v,廣度優先樹中 ...
  • 一、SQLite保存數據介紹 將資料庫保存在資料庫對於重覆或者結構化數據(比如契約信息)而言是理想之選。SQL資料庫的主要原則之一是架構:資料庫如何組織正式聲明。架構體現於用於創建資料庫的SQL語句。它有助於創建伴隨類,即契約類,其以一種系統性、自記錄的方式明確指定架構佈局。 契約類是用於定義URL ...
  • res/layout中的佈局文件太雜,沒有層次感,受不了的我治好想辦法解決這個問題。 前幾天看博客說可以使用插件分組,可惜我沒找到。知道看到另一篇博客時,才知道這個方法不能用了。 不能用插件,那就手動來吧。(http://blog.csdn.net/u011156012/article/detail ...
  • 使用Android Studio 一、在build.gradle(Module:app)添加代碼 下載,調用插件 1 apply plugin: 'com.android.application' 2 3 android { 4 compileSdkVersion 24 5 buildToolsVe ...
  • 自從Android6.0發佈以來,在許可權上做出了很大的變動,不再是之前的只要在manifest設置就可以任意獲取許可權,而是更加的註重用戶的隱私和體驗,不會再強迫用戶因拒絕不該擁有的許可權而導致的無法安裝的事情,也不會再不征求用戶授權的情況下,就可以任意的訪問用戶隱私,而且即使在授權之後也可以及時的更改 ...
  • 1. 操作系統中的棧和堆 我們先來看看一個由C/C++/OBJC編譯的程式占用記憶體分佈的結構: 棧區(stack):由系統自動分配,一般存放函數參數值、局部變數的值等。由編譯器自動創建與釋放。其操作方式類似於數據結構中的棧,即後進先出、先進後出的原則。 例如:在函數中申明一個局部變數int b;系統 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...