洛谷P1455 搭配購買(並查集縮點 01揹包)

2021-09-26 22:53:07 字數 1328 閱讀 8994

題目描述

明天就是母親節了,電腦組的小朋友們在忙碌的課業之餘挖空心思想著該送什麼禮物來表達自己的心意呢?聽說在某個**上有賣雲朵的,小朋友們決定一同前往去看看這種神奇的商品,這個店裡有n朵雲,雲朵已經被老闆編號為1,2,3,……,n,並且每朵雲都有乙個價值,但是商店的老闆是個很奇怪的人,他會告訴你一些雲朵要搭配起來買才賣,也就是說買一朵雲則與這朵雲有搭配的雲都要買,電腦組的你覺得這禮物實在是太新奇了,但是你的錢是有限的,所以你肯定是想用現有的錢買到盡量多價值的雲。

輸入格式

第1行n,m,w,表示n朵雲,m個搭配和你現有的錢的數目

第2行至n+1行,每行ci,di表示i朵雲的價錢和價值

第n+2至n+1+m ,每行ui,vi表示買ui就必須買vi,同理,如果買vi就必須買ui

輸出格式

一行,表示可以獲得的最大價值

輸入輸出樣例

輸入 #1複製

5 3 10

3 10

3 10

3 10

5 100

10 1

1 33 2

4 2輸出 #1複製

1說明/提示

30%的資料滿足:n<=100

50%的資料滿足:n<=1000;m<=100;w<=1000;

100%的資料滿足:n<=10000;0<=m<=5000;w<=10000.

思路:先並查集縮點,然後跑普通01揹包。

#include

#include

#include

using

namespace std;

const

int maxn =

10005

;int v[maxn]

,w[maxn]

,dp[maxn]

,fa[maxn]

;int v1[maxn]

,w1[maxn]

,cnt;

intfindset

(int x)

void

union

(int x,

int y)

}int

main()

for(

int i =

1;i <= m;i++

)for

(int i =

1;i <= n;i++)}

for(

int i =

1;i <= cnt;i++)}

printf

("%d\n"

,dp[sum]);

return0;

}

洛谷 P1455 搭配購買

給定n件物品 容量為sum的揹包,購買一件物品需要購買它所依賴 的物品,求最大價值 1 並查集 2 tarjan縮點 本文採取第二種方法 將乙個強連通塊縮成乙個點,費用和價值累加,最後揹包dp即可 邊集 原圖 edge i 乙個點是否在棧內 instack i 1或0 新圖 bcc cnt 新節點費...

洛谷P1455 搭配購買

題目 題解 先用並查集維護搭配,然後將多個物品 做01揹包 注 有一些num陣列為空,不能貿然進行unique,會把不為空的相同num刪去,在01迴圈時,特判一下num.v即可 include include include using namespace std const int n 10000...

洛谷P1455 搭配購買

明天就是母親節了,電腦組的小朋友們在忙碌的課業之餘挖空心思想著該送什麼禮物來表達自己的心意呢?聽說在某個 上有賣雲朵的,小朋友們決定一同前往去看看這種神奇的商品,這個店裡有n朵雲,雲朵已經被老闆編號為1,2,3,n,並且每朵雲都有乙個價值,但是商店的老闆是個很奇怪的人,他會告訴你一些雲朵要搭配起來買...