BZOJ5289 洛谷4437:[HNOI/AHOI2018]排列——題解

https://www.lydsy.com/JudgeOnline/problem.php?id=5289

https://www.luogu.org/problemnew/show/P4437

考慮對于a[i]=m,a[m]=n,我們令p[j]=i,p[k]=m(一定會有一對(j,k)滿足這個條件的),則我們會有p[k]=a[p[j]],此時我們要滿足k<j,也就是a[m]放的位置要比a[i]靠前。

也就是說選第m個之后才能選第i個。

轉換成圖論模型就是m->i <=> a[i]->i。

那么問題豁然開朗,首先如果圖中有環就能判斷無解了。

如果有解則必然為以0為根的有向樹,則答案為每個節點i被拿到的時間*w[i](前提是i的父親被拿才可以拿i)。

再考慮最大化答案,則我們讓樹中最小值min盡可能早的被拿到就好了。

繼續貪心,則如果當前局面能夠拿到min則一定拿min,換句話將就是拿了min的父親就一定拿min。

那么父親和min之間就成了捆綁關系,于是將其縮起來,在縮的過程中更新答案,然后遞歸這個過程就好了。

每次找min可以用堆維護,復雜度O(nlogn)。

(PS:更新答案,每次更新顯然是這個點前面一些點被選了,于是它一定產生了前面這些點個數*w[該點]的價值)

那么就需要考慮我們縮完的點的w要怎么計算,對于兩個集合a,b要合并,顯然用在計算上的w=wa+wb,但是用堆排序的時候就不能這么做了。

自然能想到取平均值,雖然我不會證明,不過考量一下發現差不多。

#include<cmath>
#include<queue>
#include<vector>
#include<cstdio>
#include<cctype>
#include<cstring>
#include<iostream>
#include<algorithm>
#include<ext/pb_ds/priority_queue.hpp>
using namespace std;
typedef long long ll;
typedef long double dl;
typedef pair<dl,int>pii;
#define fi first
#define se second
typedef __gnu_pbds::priority_queue<pii,greater<pii>,__gnu_pbds::pairing_heap_tag> heap;
const int N=5e5+5;
inline int read(){int X=0,w=0;char ch=0;while(!isdigit(ch)){w|=ch=='-';ch=getchar();}while(isdigit(ch))X=(X<<3)+(X<<1)+(ch^48),ch=getchar();return w?-X:X;
}
struct node{int to,nxt;
}e[N];
int n,cnt,head[N],vis[N],a[N],num,fa[N],size[N];
ll w[N],ans;
heap::point_iterator id[N];
heap q;
inline void add(int u,int v){e[++cnt].to=v;e[cnt].nxt=head[u];head[u]=cnt;
}
bool dfs(int u){vis[u]=1;num++;for(int i=head[u];i;i=e[i].nxt){int v=e[i].to;if(vis[v]||!dfs(v))return 0;}if(!u&&num<=n)return 0;return 1;
}
inline int find(int x){if(x==fa[x])return x;return fa[x]=find(fa[x]);
}
int main(){n=read();for(int i=1;i<=n;i++)a[i]=read(),add(a[i],i);for(int i=1;i<=n;i++)w[i]=read();if(!dfs(0)){puts("-1");return 0;}for(int i=0;i<=n;i++)fa[i]=i,size[i]=1;for(int i=1;i<=n;i++)id[i]=q.push(pii(w[i],i));while(!q.empty()){int u=q.top().se,v=a[u];q.pop();int rt=find(v);ans+=w[u]*size[rt];fa[u]=rt;w[rt]+=w[u];size[rt]+=size[u];if(rt)q.modify(id[rt],pii((dl)w[rt]/size[rt],rt));}printf("%lld\n",ans);return 0;
}

+++++++++++++++++++++++++++++++++++++++++++

?+本文作者:luyouqi233。               +

?+歡迎訪問我的博客:http://www.cnblogs.com/luyouqi233/+

+++++++++++++++++++++++++++++++++++++++++++

轉載于:https://www.cnblogs.com/luyouqi233/p/9112242.html

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/277906.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/277906.shtml
英文地址,請注明出處:http://en.pswp.cn/news/277906.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

集成學習-Adaboost

Adaboost 中文名叫自適應提升算法&#xff0c;是一種boosting算法。 boosting算法的基本思想 對于一個復雜任務來說&#xff0c;單個專家的決策過于片面&#xff0c;需要集合多個專家的決策得到最終的決策&#xff0c;通俗講就是三個臭皮匠頂個諸葛亮。 對于給定的數據集&#…

主動給團隊或用戶安裝Teams App

在寫這篇文章的時候&#xff0c;這個新功能還處在 Public Review&#xff0c;這意味著可能&#xff08;很小的可能性&#xff09;這里寫的方法在正式發布前還會有一些改動。 之前有一些做teams app開發的朋友問過我&#xff0c;能不能主動給一個team或者一個用戶安裝一個指定的…

thinkphp5多級控制器是什么?怎么使用?

thinkphp5多級控制器是什么&#xff1f;怎么使用&#xff1f; 一、總結 1、多級控制器是讓控制器的級數變成多級&#xff0c;也就是controller目錄下可以新建其它目錄。 2、使用的話注意目錄下的控制的的命名空間&#xff08;加上目錄名&#xff09;&#xff08;namespace app\…

給Teams消息附加圖片的三種方式

Teams消息支持三種不同的方式來添加圖片&#xff0c;這篇文章我們來一起看一下這三種方式。 Inline圖片 var imagePath Path.Combine(Environment.CurrentDirectory, "abc.png"); var imageData Convert.ToBase64String(File.ReadAllBytes(imagePath)); var image…

4月18日 MySQL學習

正式開始了數據庫的學習 昨天下好的MySQL 今天正式開始學習的&#xff0c;介紹了多種數據庫軟件&#xff0c;當然 學習的這個是開源的 免費的。 DBMS(數據庫管理系統)這就是我們學習的數據庫的軟件 數據庫分為關系型數據庫管理系統和非關系型數據庫管理系統(沒有深入的了解) 今…

企業數據湖構建之旅

摘要&#xff1a;隨著互聯網的發展&#xff0c;數據的規模和類型都呈現一個爆炸性的增長&#xff0c;對于這么多類型的數據&#xff0c;如何進行有效的管理和存儲&#xff0c;包括數據的分析&#xff0c;這是大家要面臨的一個問題。在武漢云棲大會上&#xff0c;阿里云高級產品…

用AzureFunction開發最簡單的Teams Bot

之前我有一篇文章講了如何在azure function上開發最簡單的outgoing webhook&#xff0c;收到一些反饋&#xff0c;建議我介紹一下如果在azure function上開發teams bot&#xff0c;那這篇文章就來講一下如何用function來快速開發bot。 我們先創建一個azure function資源&#…

20189215 2018-2019-2 《密碼與安全新技術專題》第7周作業

課程&#xff1a;《密碼與安全新技術專題》 班級&#xff1a; 1892班 姓名&#xff1a; 李煬 學號&#xff1a;20189215 上課教師&#xff1a;謝四江 上課日期&#xff1a;2019年4月9日 必修/選修&#xff1a; 選修 1.本次講座的學習總結 講座主題&#xff1a;信息隱藏 信息隱藏…

BZOJ1565[NOI2009]植物大戰僵尸——最大權閉合子圖+拓撲排序

題目描述 Plants vs. Zombies&#xff08;PVZ&#xff09;是最近十分風靡的一款小游戲。Plants&#xff08;植物&#xff09;和Zombies&#xff08;僵尸&#xff09;是游戲的主角&#xff0c;其中Plants防守&#xff0c;而Zombies進攻。該款游戲包含多種不同的挑戰系列&#xf…

推送ActivityFeed到Teams

幾個月前&#xff0c;Teams 團隊又推出了新的 Graph API&#xff0c;讓 app 可以給用戶發送 Activity Feed。我們來看看如何做。 首先&#xff0c;我們的app需要使用較新的 manifest 1.7版本&#xff0c;當然如果使用最新的1.8版本就更好了。在manifest json中添加 webApplica…

RecycleView彈性滑動

還有點bug&#xff0c;建議使用 LinearSnapHelper rvPilotList.addOnScrollListener(new RecyclerView.OnScrollListener() {Overridepublic void onScrolled(NonNull RecyclerView recyclerView, int dx, int dy) {super.onScrolled(recyclerView, dx, dy);// …

關于深度學習,這些知識點你需要了解一下

深度學習概述 o 受限玻爾茲曼機和深度信念網絡 o Dropout o 處理不平衡的技巧 o SMOTE&#xff1a;合成少數過采樣技術 o 神經網絡中對成本敏感的學習 深度學習概述 在2006年之前&#xff0c;訓練深度監督前饋神經網絡總是失敗的&#xff0c;其主要原因都是導致…

發送不同類型的ActivityFeed

上一篇文章講到了如何使用最新的Graph API來給一個用戶發送一個簡單的 Activity Feed。我們這篇文章來詳細講一下發送三種不同類型的消息。 發送 Chat 相關的 Activity Notification API 為 POST https://graph.microsoft.com/beta/chats/{chat-id}/sendActivityNotification…

git add * 提示warning: LF will be replaced by CRLF in 解決辦法

在使用git的時候&#xff0c;每次執行 $ git add * 都會提示這樣一個警告消息&#xff1a; 雖然說沒有什么影響吧。 不過就是覺得太礙眼了&#xff0c; 按照這樣設置就沒有問題了: git config core.autocrlf false 這樣設置git的配置后在執行add操作就沒有問題了。 奮斗的年紀你…

git 放棄本地修改,強制拉取更新

開發時&#xff0c;對于本地的項目中修改不做保存操作&#xff08;或代碼改崩&#xff09;&#xff0c;可以用到Git pull的強制覆蓋&#xff0c;具體代碼如下&#xff1a; git fetch --all git reset --hard origin/master git pull //可以省略 git fetch 指令是下載遠程倉庫最…

發送ActivityFeed的隱藏功能

前兩篇文章介紹了如何發送 activity notification&#xff0c;這篇文章主要介紹兩個隱藏功能&#xff0c;實際上所謂的隱藏功能是指大家在閱讀官方文檔是會忽略的兩個點&#xff0c;但是實際上也是很實用的兩個功能點。 text 類型的 topic 之前文章中提到我們的 activity not…

Dispatch Queue 之 Invoke 當前隊列

&#xfffc; 轉載于:https://www.cnblogs.com/huahuahu/p/dispatch-queue-zhi-invoke-dang-qian-dui-lie.html

js或jQuery獲取當前屏幕的各種高度

Javascript: 網頁可見區域寬&#xff1a; document.body.clientWidth 網頁可見區域高&#xff1a; document.body.clientHeight 網頁可見區域寬&#xff1a; document.body.offsetWidth (包括邊線的寬) 網頁可見區域高&#xff1a; document.body.offsetHeight (包括邊線的高) …

Teams數據統計 - 用戶在線離線狀態

前幾天我在wechat的moments里看到以為朋友發了騰迅會議的對用戶個人的年度數據統計&#xff0c;看上去很有大數據感。 實際上 Teams 也具備的類似的能力&#xff0c;只是它把這個能力開放給了開發人員&#xff0c;我們可以通過強大的 Graph API&#xff0c;獲取大量的數據信息&…

我們是如何通過全球第一免費開源ERP Odoo做到項目100%交付

傳統友商ERP的交付過程 一、先初步需求調研&#xff0c;后選型功能模塊 傳統友商ERP第一件事情先對客戶方進行初步的調研&#xff0c;客戶方無論說什么&#xff0c;友商聽過算過&#xff0c;只關心你人數多少&#xff0c;有哪些人涉及到哪些模塊&#xff0c;接著對模塊進行所謂…