日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

浅析拯救小矮人的 nlogn 算法及其证明

發布時間:2023/12/10 编程问答 34 豆豆
生活随笔 收集整理的這篇文章主要介紹了 浅析拯救小矮人的 nlogn 算法及其证明 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

淺析拯救小矮人的 nlogn 算法及其證明



題型簡介:

有 $ n $ 個人,第 $ i $ 個人身高 $ a_i $ 手長 $ b_i $ ,他們為了從一個高為 $ H $ 的洞中出去,決定搭人梯。如果一個人和他下面的人的身高之和加上他的手長可以達到洞的高度,那么他就可以出去。求最多有多少人能出去。 $ n\leq 10^6 $



算法流程

本題需要貪心,所以我們可以貪心到底。首先我們將所有人,按照他們的最低逃生高度 $ H-a_i-b_i $ 從高到低排序。一個必須要知道的結論:最低逃生高度越高的人,一定越先走

首先我們將所有人按照 $ H-a_i-b_i $ (最低逃生高度)從高到低排序,根據結論越高的人越先走。然后如果是 $ n^2 $ 背包,就是對每個人做有條件的背包,模擬每個人是否能走。

而 $ n\times logn $ 的方法則是記錄一個后綴 $ s[] $ ,其中 $ s[i] $ 表示第 $ i $ 個人后面最低逃生高度比他低的所有人的身高總和,然后用一個 $ tot $ 記錄前面沒有出去的人的身高總和,對于從高到低枚舉的第 $ i $ 個人,如果 $ s[i]+tot>=H-a_i-b_i $ 就說明他能出去(于是默認他出去);否則就將這個人的身高和前面所有已經出去的人的身高作比較,如果當前這個人最高那么他就不出去了,不然就從前面已經出去的人里面找到那個最高的人,把他拉回洞里墊在下面,讓當前這個人出去!照著這個過程做我們就能得到最優解。


算法證明:

其實這個算法只有兩個待考究的地方,問題一:為什么最低逃生高度高的人,一定越先走?這個問題在很多題解里已經討論過了,難以講清,本題不做多講,就用一張圖感性一下:

本算法第二個問題在于這句話: 否則就將這個人的身高和前面所有已經出去的人的身高作比較,如果當前這個人最高那么他就不出去了,墊到下面去;不然就從前面已經出去的人里面找到那個最高的人,把他拉回洞里墊在下面,讓當前這個人出去!為什么把上面最高的那個人拉下來,這個人就一定可以出去了?為什么只取一個人下來,我們可不可以拉多個人下來,讓當前這個人出去的同時為后面的人墊高度?這個我們用兩張圖解讀:



$ code: $

#include<iostream> #include<cstdio> #include<iomanip> #include<algorithm> #include<cstring> #include<cstdlib> #include<ctime> #include<cmath> #include<vector> #include<queue> #include<map> #include<set>#define ll long long #define db double #define rg register intusing namespace std;int n,H; //人數;陷阱高度 int tot,ans; //之前沒能逃生的人的身高總和;答案 int s[200005]; // s[i]表示在第i個人后面逃生的所有人的身高總和,就是后綴和 priority_queue<int> q; //用來求之前已經逃生的人中,身高最高的人struct su{int a,b,h,id; //身高,手長,最低逃生高度,編號inline bool operator <(const su &i)const{return h>i.h; //按最低逃生高度,從高到底排序 } //(其實說白了就是逃生能力排序,為了方便理解就詳細一點) }p[200005]; //存小矮人信息的數組 peopleinline int qr(){ //快讀register char ch; register bool sign=0; rg res=0;while(!isdigit(ch=getchar()))if(ch=='-')sign=1;while(isdigit(ch))res=res*10+(ch^48),ch=getchar();if(sign)return -res; else return res; }int main(){n=qr();for(rg i=1;i<=n;++i)p[i].a=qr(),p[i].b=qr();H=qr();for(rg i=1;i<=n;++i){p[i].h=H-p[i].a-p[i].b; //最低逃生高度p[i].id=i; //每個人的編號}sort(p+1,p+n+1);for(rg i=n;i>=1;--i)s[i]=s[i+1]+p[i+1].a; //s[i]表示在第i個人后面逃生的所有人堆起來達到的高度for(rg i=1;i<=n;++i){if(tot+s[i]>=p[i].h) q.push(p[i].a), ++ans;//如果在他前面不能逃生的人加上在他后面的人堆起來達到了他的最低逃生高度,就讓他走else{if(!q.empty()&&q.top()>p[i].a){ //拿出之前最大的身高和他對比,較大的走tot+=q.top();q.pop(); --ans;q.push(p[i].a); ++ans; //其實ans根本沒變,為了高度還原就這樣了} else tot+=p[i].a; //否則這個就墊到下面去}}printf("%d\n",ans);return 0; }

轉載于:https://www.cnblogs.com/812-xiao-wen/p/11545341.html

總結

以上是生活随笔為你收集整理的浅析拯救小矮人的 nlogn 算法及其证明的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

主站蜘蛛池模板: 久久天天躁狠狠躁夜夜躁 | 亚洲美女影院 | 国产涩涩| 欧美成人精品欧美一级乱黄 | 亚洲高清欧美 | 色综合av综合无码综合网站 | 香蕉爱爱视频 | 成人免费视频国产在线观看 | 三级福利 | 日韩欧美在线观看一区二区三区 | 国产做受网站 | 亚洲AV无码成人精品区在线观 | 最新视频 - 8mav | 国产精品另类 | 深夜福利视频在线 | 成年人视频在线观看免费 | 久久综合成人网 | 亚洲第一在线 | 国产第一福利影院 | 特级西西444www大精品视频免费看 | 久久久久二区 | 亚洲综合在线一区 | 欧美日韩在线视频一区 | 亚洲精品99久久久久中文字幕 | www.天天射 | 亚洲一区二区久久 | 老汉色av | yw视频在线观看 | 依依成人在线视频 | 亚洲激情一区二区三区 | 一极黄色大片 | 椎名由奈av一区二区三区 | 国产日韩欧美不卡 | 91成人一区 | 欧美性网站 | 成人一级影视 | 亚洲无圣光 | 国偷自拍| 免费看黄网址 | 国产九九九九九 | 久久免费播放视频 | 国产一级片免费在线观看 | 亚洲精品一二三四 | 国产大尺度视频 | 免费看av软件 | 日韩在线视频网址 | 亚洲蜜桃在线 | 日韩精品资源 | 成人毛片18女人毛片免费 | 国产三级精品三级在线观看 | 亚洲狼人色 | 老头老太做爰xxx视频 | 姑娘第5集高清在线观看 | 亚洲天堂av在线免费观看 | 成人性爱视频在线观看 | av电影免费在线播放 | 综合在线一区 | 久久合| 久久青青操 | 国产chinese男男网站大全 | 中日黄色片 | 国 产 黄 色 大 片 | 国产精品无码人妻一区二区在线 | 国产91色| 欧美美女黄色 | 激情在线观看视频 | 欧美日韩一区二区三区在线 | 欧美一级影院 | 日本视频色 | 在线免费黄色网址 | 中文字幕精品无码亚 | 国产在线精品视频 | 亚洲欧洲免费 | 香蕉久操| 亚洲自拍网站 | 天天综合天天添夜夜添狠狠添 | 国产ts系列 | 成年人激情网 | 中文字幕福利 | 丰满秘书被猛烈进入高清播放在 | 亚洲免费影视 | 成人动漫一区二区三区 | 老外一级黄色片 | 91成人短视频在线观看 | www.国产视频.com| 国精产品一区一区三区有限公司杨 | 波多野42部无码喷潮在线 | 无码国产精品一区二区高潮 | 国产精品久久久久久久久晋中 | 精品中文字幕一区 | 色婷婷久久五月综合成人 | 国产亚洲精品女人久久久久久 | 小泽玛利亚一区二区三区视频 | 在线观看v片 | 日本精品在线观看视频 | 亚洲a级精品 | 日批免费观看视频 | 欧美一区二区高清 | 加勒比一区二区 |