слабый амфитеатра CF741B Арпа и ценен Шланги непересекающихся набора 01 рюкзак Мердад в

заглавие

CF741B

Упростить смысл вопросов:

Там \ (п \) Персональные \ ((1 <п -. <= 1000) \ =) , каждый из которых имеет вес \ (w_i (1 \ leqslant w_i \ leqslant 1000) \) и значение очарование \ (b_i (1 \ b_i leqslant \ leqslant 10 ^ 6) \) .

\ (П- \) существует между отдельными людьми \ ({п-1) п (} {2}, 10 ^ 5)) \ т (1 \ leqslant м \ leqslant мин (\ гидроразрыва) связь. Первая \ (я \) отношения между двумя числами \ (x_i \) и \ (y_i \) форма, что первая \ (x_i \) Физические и \ (\) y_i личные друзья, друг отношения двунаправленным.

Известен если \ (а \) и \ (Ь \) является другом, \ (Ь \) и \ (с \) является другом, то \ (а \) и \ (с \) является другом. Теперь \ (Mehrdad \) , чтобы пригласить некоторые люди пришли к партии, так что общий вес этих людей не превышает \ (w_i (1 \ leqslant w_i \ leqslant 1000) \) и Харизма сумму , как большая , насколько это возможно. С кругом друзей , которые могут только пригласить одного из них, или всех лиц, либо лицо не пригласили.

анализ

  1. Кто определяется в той же самой группе, так что думать непересекающихся-набора. Тогда используйте \ (вектор \) контейнеры будут храниться вместе в одной и той же группе людей.
  2. В соответствии с указанными выше требованиями к каждому контейнеру людей либо принимать все, или только принимать или не принимать, то это на самом деле простой \ (01 \) задача о рюкзаке.
  3. Так что этот вопрос решается, говоря IQ!

код

#include<bits/stdc++.h>

#define file(s) freopen(s".in","r",stdin), freopen(s".out","w",stdout)

#define G ch=getchar()
#define DeBug(x) std::cout<<#x<<':'<<x<<std::endl

const int MaxN=1e3+10;

namespace IO
{
    char buf[1<<15],*fs,*ft;
    inline char getc() { return (ft==fs&&(ft=(fs=buf)+fread(buf,1,1<<15,stdin),ft==fs))?0:*fs++; }
    template<typename T>inline void read(T &x)
    {
        x=0;
        T f=1, G;
        while (!isdigit(ch) && ch^'-') G;
        if (ch=='-') f=-1, G;
        while (isdigit(ch)) x=(x<<1)+(x<<3)+(ch^48), G;
        x*=f;
    }

    char Out[1<<24],*fe=Out;
    inline void flush() { fwrite(Out,1,fe-Out,stdout); fe=Out; }
    template<typename T>inline void write(T x,char str)
    {
        if (!x) *fe++=48;
        if (x<0) *fe++='-', x=-x;
        T num=0, ch[20];
        while (x) ch[++num]=x%10+48, x/=10;
        while (num) *fe++=ch[num--];
        *fe++=str;
    }
}

using IO::read;
using IO::write;

template<typename T>inline bool chkMin(T &a,const T &b) { return a>b ? (a=b, true) : false; }
template<typename T>inline bool chkMax(T &a,const T &b) { return a<b ? (a=b, true) : false; }
template<typename T>inline T min(T a,T b) { return a<b ? a : b; }
template<typename T>inline T max(T a,T b) { return a>b ? a : b; }

namespace Union_Set
{
    int fa[MaxN];
    inline int get(int x)
    {
        return fa[x]==x ? x : fa[x]=get(fa[x]);
    }

    inline void merge(int x, int y)
    {
        int fx=get(x), fy=get(y);
        if (fx^fy) fa[fx]=fy;
    }
}

using Union_Set::get;
using Union_Set::merge;

int w[MaxN], b[MaxN], f[MaxN];
std::vector<int> g[MaxN];
int main()
{
    int n, m, W;
    read(n), read(m), read(W);//总重
    for (int i=1; i<=n; ++i) read(w[i]);//重量
    for (int i=1; i<=n; ++i) read(b[i]);//魅力值

    for (int i=1; i<=n; ++i) Union_Set::fa[i]=i;
    for (int i=1, x, y; i<=m; ++i) read(x), read(y), merge(x, y);

    for (int i=0; i<MaxN; ++i) g[i].clear();
    for (int i=1; i<=n; ++i) g[get(i)].push_back(i);

    memset(f, 0, sizeof(f));
    for (int i=1; i<=n; ++i)
    {
        if (get(i)^i) continue;//一个人也不邀请
        for (int j=W; j>=0; --j)
        {
            int sumw=0, sumb=0;
            for (int k=0; k<(int)g[i].size(); ++k)//或者只能邀请其中的一个人
            {
                sumw+=w[g[i][k]], sumb+=b[g[i][k]];
                if (j>=w[g[i][k]]) chkMax(f[j], f[j-w[g[i][k]]]+b[g[i][k]]);
            }
            if (j>=sumw) chkMax(f[j], f[j-sumw]+sumb);//或者全部人
        }
    }
    write(f[W], '\n');
    IO::flush();
    return 0;
}

рекомендация

отwww.cnblogs.com/G-hsm/p/CF741B.html
рекомендация