B. Party - 思维 + 图

news/2024/7/24 11:06:38 标签: 算法, c++, 思维

题面

分析

可以发现只需要保留最大的偶数条关系,假如 m m m本身就是偶数,那么答案一定是0,如果 m m m不是偶数,把么就需要减去奇数条关系使剩余关系变成偶数条,那么第一种方法,可以减去某一个人,这个人的朋友有奇数个,减去这个人也就意味着减去奇数条关系;第二种方法,可以减去一对朋友,这一对朋友必须满足都有奇数个朋友,因为,减去这一对朋友中的其中一个后,会减少偶数条关系,但是此时剩余的朋友由于失去了和减去的朋友的那一条关系,那么他还剩奇数条关系,在减去他也就相当于减去了奇数条关系,也可以得到答案,最后将两种情况所有情况取最小值就可以了。

代码

#include <bits/stdc++.h>

using namespace std;
using ll = long long;

void solve() {
    int n, m;
    cin >> n >> m;
    vector<int> a(n + 1);
    vector<int> u(m), v(m);
    vector<int> cnt(n + 1);
    for(int i = 1; i <= n; i ++) cin >> a[i];
    for(int i = 0; i < m; i ++) {
        cin >> u[i] >> v[i];
        cnt[u[i]] ++;
        cnt[v[i]] ++;
    }
    if(m % 2 == 0) {
        cout << 0 << "\n";
        return ;
    }
    int ans = 1e9;
    for(int i = 1; i <= n; i ++) {
        if(cnt[i] & 1) {
            ans = min(ans, a[i]);
        }
    }
    for(int i = 0; i < m; i ++) {
        if(cnt[u[i]] % 2 == 0 && cnt[v[i]] % 2 == 0) {
            ans = min(ans, a[u[i]] + a[v[i]]);
        }
    }
    cout << ans << "\n";
}

int main() {
    ios::sync_with_stdio(false);
    cin.tie(nullptr);

    int T;
    cin >> T;
    while(T --) {
        solve();
    }
}

http://www.niftyadmin.cn/n/5110006.html

相关文章

专题二:滑动窗口【优选算法】

滑动窗口&#xff1a; 什么时候用&#xff1f; 同向双指针&#xff08;找单调性&#xff09; 怎么用&#xff1f; 1&#xff09;用left、right指针维护窗口 2&#xff09;进窗口&#xff08;right指针&#xff0c;更新窗口内的值&#xff09; 3&#xff09;判断 出窗口&#xf…

ReentrantLock与synchronized区别之比较(面试)

背景&#xff1a; 我们Java开发中需要保证数据线程安全时有多重选择&#xff0c;直接使用线程安全的集合类&#xff0c;或者某些变量我们通过ReentrantLock来保证安全&#xff0c;或者使用synchronized关键字&#xff0c;那两者有何区别&#xff1f; 备注&#xff1a; Reent…

2023年中国工业空气加热器市场规模及存在问题分析[图]

工业空气加热器行业是指涉及工业领域中空气加热设备的制造、销售、安装和维护的产业。这个行业专注于生产用于加热空气的设备&#xff0c;以满足工业生产过程中的加热需求。工业空气加热器可以采用各种不同的加热技术&#xff0c;如电加热、燃气加热、蒸汽加热等&#xff0c;用…

基于springboot实现财务管理系统项目【项目源码+论文说明】

基于springboot实现财务管理系统演示 摘要 随着信息技术和网络技术的飞速发展&#xff0c;人类已进入全新信息化时代&#xff0c;传统管理技术已无法高效&#xff0c;便捷地管理信息。为了迎合时代需求&#xff0c;优化管理效率&#xff0c;各种各样的管理系统应运而生&#x…

8.2 C++ 引用与取别名

C/C语言是一种通用的编程语言&#xff0c;具有高效、灵活和可移植等特点。C语言主要用于系统编程&#xff0c;如操作系统、编译器、数据库等&#xff1b;C语言是C语言的扩展&#xff0c;增加了面向对象编程的特性&#xff0c;适用于大型软件系统、图形用户界面、嵌入式系统等。…

【Arduino TFT】基于 ESP32S3 S7789 240x240 TFT实现的龙猫太空人天气时钟

忘记过去&#xff0c;超越自己 ❤️ 博客主页 单片机菜鸟哥&#xff0c;一个野生非专业硬件IOT爱好者 ❤️❤️ 本篇创建记录 2023-10-21 ❤️❤️ 本篇更新记录 2023-10-21 ❤️&#x1f389; 欢迎关注 &#x1f50e;点赞 &#x1f44d;收藏 ⭐️留言&#x1f4dd;&#x1f64…

安装与脏数据绕过_安全狗

1安全狗 1.1 环境准备 安全狗safedogwzApacheV3.5.exe&#xff0c;安装步骤省略&#xff0c; pikachu环境&#xff1a;https://zhuanlan.zhihu.com/p/568493971 安装注意事项&#xff1a;安装完后php和web服务都需要重启 注意事项&#xff1a;服务名php版本保持一致 安装过…

基于springboot实现财务管理系统项目【项目源码+论文说明】计算机毕业设计

基于springboot实现财务管理系统演示 摘要 随着信息技术和网络技术的飞速发展&#xff0c;人类已进入全新信息化时代&#xff0c;传统管理技术已无法高效&#xff0c;便捷地管理信息。为了迎合时代需求&#xff0c;优化管理效率&#xff0c;各种各样的管理系统应运而生&#x…