演算法導論之線上找女朋友問題

来源:http://www.cnblogs.com/joey-hua/archive/2016/01/08/5113240.html
-Advertisement-
Play Games

問題:假設你需要找一個女朋友。你先前的尋找嘗試都以失敗告終,所以你決定找一個相親代理。相親代理每天給你推薦一個女孩紙。你會面談此人,然後決定要不要與她交往。你必須付給相親代理一小筆費用來面談。要真正地找到一個女朋友則要花更多的錢,因為你必須和目前的女朋友分手,還要付一大筆中介費給相親代理。你的諾言是...


問題:假設你需要找一個女朋友。你先前的尋找嘗試都以失敗告終,所以你決定找一個相親代理。相親代理每天給你推薦一個女孩紙。你會面談此人,然後決定要不要與她交往。你必須付給相親代理一小筆費用來面談。要真正地找到一個女朋友則要花更多的錢,因為你必須和目前的女朋友分手,還要付一大筆中介費給相親代理。你的諾言是在任何時候,都要找到最佳人選來成為你的女朋友。因此,你決定在面談完每個應邀的女孩紙後,如果這個女孩紙比目前的女朋友更有資格,你就會和目前的女朋友分手,然後和這個新的女朋友交往。你願意為這種策略而付出費用,但希望能夠預測這種費用會是多少。

現在我們來考慮這個問題的一個變形。假設現在我們不希望面談所有的應邀的女孩紙來找到最好的一個,也不希望因為不斷有更好的申請者出現而不停地和新人交往與舊人分手。我們願意交往接近最好的應邀的女孩紙,只交往一次。我們必須遵守的一個要求:在每次面談後,必須或者立即和應邀者交往,或者告訴應邀者他們將無法得到這個交往的機會。在最小化面談次數和最大化和應邀者交往的質量兩方面如何取得平衡?

解答:

可以通過以下方式來對這個問題建模。在面談一個應邀者之後,我們能夠給他一個分數;令score(i)表示給第i位應邀者的分數,並且假設沒有兩個應邀者的分數相同。在面談j個應邀者之後,我們知道其中哪一個分數最高,但是不知道在剩餘的n-j個應邀者中會不會有更高分數的應邀者。我們決定採用這樣一個策略:選擇一個正整數k<n,面談前k個應邀者然後拒絕他們,再交往其後比前面的應邀者有更高分數的第一個應邀者。如果結果是最好的應邀者在前k個面談的之中,那麼我們將交往第n個應邀者。這個策略形式化地表示在如下所示的過程ONLINEMAXIMUM(k,n)中,該過程返回的是我們希望交往的應邀者的下標值。

 

/**
* 
* @param k 前k個被拒絕的應邀者
* @param n 總共n個應邀者
* @return
*/
int ONLINEMAXIMUM(int k, int n){
	int[] score = new int[n];
1	int bestscore = -999999;
2	for(int i = 1; i < k; i++){
3		if(score[i] > bestscore){
4			bestscore = score[i];
		}
	}
5	for (int i = k+1; i < n; i++) {
6		if(score[i] > bestscore){
7			return i;
		}
	}
8	return n;
}

 

對每一個可能的k值,我們希望確定交往到最好的應邀者的概率。然後選擇最佳的k值,並用此值來實現這個策略。先假設k是固定的。令M(j)=maxa<=i<=b{score(i)}表示應邀者a到b中的最高分數。令S表示我們成功選擇最好的應邀者的事件,Si表示當最好的應邀者是第i個面談者時成功的事件。由於不同的Si不相交,有註意到當最好的應邀者是前k個應邀者中的一個時,我們不會成功,有

Pr{Si}=0,i=1,2,...,k。於是得到

   公式2

現在我們來計算Pr{Si}。為了當第i個應邀者是最好的時成功,有兩件事情必鬚髮生。首先,最好的應邀者必須在位置i上,用事件Bi表示。其次,演算法不能選擇在位置k+1到i-1中的任何一個應邀者,而這個選擇僅發生在當j滿足k+1<=j<=i-1時,程式第6行有score[j]<bestscore。(因為分數是唯一的,可以忽略score[j]=bestscore的可能性。)換言之,所有score[k+1]到score[i-1]的值都必須小於M(k);如果其中有大於M(k)的數,將返回第一個大於M(k)的數的下標。用Oi表示在位置k+1到i-1中沒有任何應邀者被選取的事件。幸運的是,事件Bi和Oi是獨立的。事件Oi只依賴於位置1到i-1中數值的相對次序,而Bi只依賴於位置i的數值是否大於所有其他位置的數值。位置1到i-1中各數值的相對次序如何,並不應影響位置i的值是否大於位置1到i-1中的所有數值,而且位置i的值也不會影響位置1到i-1中值的次序。因此,應用公式1得

Pr{Si}=Pr{Bi∩Oi}=Pr{Bi}Pr{Oi}

Pr{Bi}的概率顯然是1/n,因為最大值等可能地是n個位置中的任何一個。如果事件Oi要發生,在位置1到i-1中的最大值必須在前k個位置的一個,而且最大值等可能地是i-1個位置中的任何一個。因此,Pr{Oi}=k/(i-1),Pr{Si}=k/(n(i-1))。利用公式2有

我們利用積分來近似約束這個和數的上界和下界。根據不等式公式3,有

解這些定積分可以得到下麵的界:

這提供了Pr{S}的一個相當緊確的界。由於我們希望最大化成功的概率,因而主要關註如何選取k的值,使其能夠最大化Pr{S}的下界。(除此之外,下界表達式比上界表達式容易最大化。)將表達式(k/n)(lnn-lnk)對k求導,得

令此導數等於0,我們看到當lnk=lnn-1=ln(n/e),或等價地,當k=n/e時,概率的下界最大化。因此,如果用k=n/e來實現我們的策略,則可以以至少為1/e的概率,成功地交往到最有資格的應邀者。

 

公式1:Pr{A∩B}=Pr{A}Pr{B}

公式3:當f(k)單調遞減時,可以使用積分來計算界


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

-Advertisement-
Play Games
更多相關文章
  • 初學android,捧著一本書,第一個接觸的就是adb,在android路上...
  • tag是UIView的一個屬性,而且要求tag值唯一。父視圖可以通過tag來找到一個子視圖1 UIView *redView = [[UIView alloc]initWithFrame:CGRectMake(0, 0, CGRectGetWidth(self.window.frame), ...
  • RadioButton(單選框)和CheckBox(覆選框)講解:一、基本用法和事件處理(1)RadioButton單選框,就是只能選擇其中的一個,我們在使用的時候需要將RadioButton放到RadioGroup中使用,同時我們還可以在RadioGroup中設置 orientation屬性來控制...
  • 一.先來研究下這個軟體-》Appicon and Launchimage Maker首先打開你電腦上的AppStore,然後搜索:AppIcon然後回車:這裡我們先使用免費版的點擊下載。(左上角那個)然後打開軟體,應該是這樣的:軟體好人性化,給我們標註了1,2,3該幹啥。1選圖片唄。2.選是要給什麼...
  • 在平時的工作中,會經常用到adb命令,在這裡稍微整理了一下。一.概要1.什麼是adb?adb全稱為Android Debug Bridge,就是起到調試橋的作用。顧名思義,adb就是一個debug工具。2.adb工作原理不是很理解?那就來看看它的工作原理吧。上圖是一個簡單的adb工作原理圖。adb客...
  • 聲明:本文源碼出自實現雪花飛舞效果(有改動)主要通過這篇文來分析自定義view的實現過程。沒事時,比較喜歡上網看看一些新的東西,泡在網上的日子就是一個很不錯的網站。下麵開始了,哈哈。^_^ 大家都知道,自定義view分成三個類型,1、是完全自定義,自己繪製,例如本文講的例子。2、是Groupvie....
  • 下文中的Linux只表示公司72 CI伺服器配置,基它Linux伺服器和Mac電腦可供參考。
  • 現場保護當一個活動進入到了停止的狀態,是有可能被系統回收的,我們都學過Activity的生命周期當活動處於onPause() ,onStop() ,onDestroy() 三種狀態時程式可能會被Android系統回收掉,這時如果之前未進行保護操作把數據保存的話就會造成用戶在程式當中的數據或者修改丟失...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...