codeforces round #429 div2

竟然还涨分了。。。rank500+还能涨我rating是有多低。。。

AB不写了

C:类似找规律,具体证明看edtorial

#include<bits/stdc++.h>
using namespace std;
const int N = 200010;
int m;
struct data {
    int b, id;
    bool friend operator < (data A, data B)
    {
        return A.b < B.b;
    }
} x[N], y[N];
int ans[N];
int main()
{
    scanf("%d", &m);
    for(int i = 1; i <= m; ++i) 
    {
        scanf("%d", &x[i].b);
        x[i].id = i;
    }
    for(int i = 1; i <= m; ++i)
    {
        scanf("%d", &y[i].b);
        y[i].id = i;
    }
    sort(y + 1, y + m + 1);
    sort(x + 1, x + m + 1);
    for(int i = 1; i <= m; ++i) ans[y[i].id] = x[m - i + 1].b;
    for(int i = 1; i <= m; ++i) printf("%d ", ans[i]);
    return 0;
}
View Code

D:首先度数是奇数是不行的,这样是无解,所以我们拿出一个-1让度数变成偶数,然后实行染色,如果当前度数和是偶数就不连,是奇数就得连

#include<bits/stdc++.h>
using namespace std;
const int N = 300010;
int n, m, cnt;
int a[N], vis[N], b[N];
vector<int> G[N], e[N], ans;
bool flag;
void dfs(int u)
{
    vis[u] = 1;
    if(a[u] == 1) b[u] = 1;
    for(int i = 0; i < G[u].size(); ++i)
    {
        int v = G[u][i];
        if(vis[v]) continue;
        dfs(v);
        if(b[v] & 1) ans.push_back(e[u][i]);
        b[u] += b[v];
    }
}
int main()
{
    int pos = -1;
    scanf("%d%d", &n, &m);
    for(int i = 1; i <= n; ++i) 
    {
        scanf("%d", &a[i]);
        if(a[i] == 1) ++cnt;
        if(a[i] == -1) pos = i;
    }
    for(int i = 1; i <= m; ++i)
    {
        int u, v;
        scanf("%d%d", &u, &v);
        G[u].push_back(v);
        G[v].push_back(u);
        e[u].push_back(i);
        e[v].push_back(i);
    }
    if(cnt & 1)
    {
        if(pos == -1)
        {
            puts("-1");
            return 0;
        }
        a[pos] = 1;
    }
    dfs(1);
    printf("%d
", ans.size());
    sort(ans.begin(), ans.end());
    for(int i = 0; i < ans.size(); ++i) printf("%d
", ans[i]);
    return 0;
}
View Code

editorial给太晚,差评

原文地址:https://www.cnblogs.com/19992147orz/p/7402395.html