题解 | 小红的二分图构造

小红的二分图构造

https://www.nowcoder.com/practice/3ea0887a796b479ea9f336a8a97a405d

#include <iostream>
#include <vector>
using namespace std;

bool dfs(const int& first, const int& sum, const int& target, const int& n, const vector<int>& d, vector<int>& v1, vector<int>& v2){
    if(sum == target){
        if(first != n){
            for(int i=first; i<n; ++i){
                v2.emplace_back(i+1);
            }
        }
        return true;
    }else if(sum > target){
        return false;
    }
    for(int i=first; i<n; ++i){
        v1.emplace_back(i+1);
        if(dfs(i+1, sum+d[i], target, n, d, v1, v2)){
            return true;
        }else{
            v1.pop_back();
            v2.emplace_back(i+1);
            if (dfs(i + 1, sum, target, n, d, v1, v2)) {
                return true;
            }
            v2.pop_back();
            return false;
        }
    }
    
    return false;
}

int main() {
    int n;
    cin >> n;
    vector<int> d(n);
    int sum = 0;
    for(int i=0; i<n; ++i){
        cin >> d[i];
        sum += d[i];
    }
    if(sum%2==1){
        cout << -1 << endl;
        return 0;
    }
    vector<int> v1, v2;
    if(!dfs(0, 0, sum/2, n, d, v1, v2)){
        cout << -1 << endl;
        return 0;
    }
    cout << sum/2 << endl;
    int i = 0, j = 0;
    int n1 = v1.size();
    int n2 = v2.size();
    while(i < n1 && j < n2){
        cout << v1[i] << ' ' << v2[j] << endl;
        d[v1[i]-1] --, d[v2[j]-1] --;
        if (d[v1[i]-1] == 0) i ++;
        if (d[v2[j]-1] == 0) j ++;
    }

    return 0;
}
// 64 位输出请用 printf("%lld")

全部评论

相关推荐

缓解焦虑的最好方法是回家。鼠鼠昨天上午考完了本科阶段的最后一场考试,大概率考得稀烂,但是没多想,考完立马收拾行李,坐上了提前约好的顺风车飞奔回家。虽然家和学校很近,只有一百多公里的路程,但距离上次回家也已经有三四个月了。每次想回家,期间总有考试、毕业设计、面试、实习等等各种各样的原因,没办法回去,待在学校和公司的每一天也都充斥着无形的压力和焦虑。现在终于完成了答辩,考完了试,公司那边也请了假,是时候回去一趟了。没有提前通知爸妈,想给他们一个惊喜。下午提前到了家,他俩还在上班,只好让外公外婆来给我开门。因为我的回家,晚上外婆在厨房格外忙碌,做了满满一大桌子菜,填饱了我天天吃外卖的肚子。晚上也没空...
梦想是成为七海千秋:取决于家庭吧?其实回家更焦虑了,每天起床父母都问实习找好了没简历投递了没今天有没有面试,但是又没有什么结果,玩两下手机父母就会说你看你啥也没找到为什么天天就知道刷手机,怎么不去学习…我现在就希望我能永远在外面实习,报喜不报忧,等拿到一个好offer再回家
点赞 评论 收藏
分享
点赞 评论 收藏
分享
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务