当前位置: 首页 > news >正文

问题 H: 棋盘游戏(二分图变式)

 题意:要求找到

不放车就无法达到最大数的点                     的个数

题解:1.以行列绘制二分图

           2.先算出最大二分匹配数

           3.依次遍历所有边

  删除该边,并计算二分匹配最大值

(若小于原最大值即为重要点),再恢复该边

以下为AC代码:

#include<string.h>
#include<iostream>
using namespace std;// 声明棋盘
int map[109][109] = { 0 };// 限制访问
int visit[109] = { 0 };// 右侧对象数组
int r[109] = { 0 };// 声明棋盘行列,棋子个数
int line = 0, row = 0, num = 0;// 二分匹配
bool find(int x);// 求最大匹配数
int max1();// 遍历删除并恢复所有边,求影响最大二分匹配的边
int max2();// 声明最大二分匹配数
int ans = 0;// 记录各边左右端点对应的下标
int k = 0;
int main()
{// 声明棋盘编号int n = 1;while (scanf("%d%d%d", &line, &row, &num) != EOF){memset(map, 0, sizeof(map));for (int i = 0; i < num; i++){int tl = 0, tr = 0;scanf("%d %d", &tl, &tr);map[tl][tr] = 1;}ans = max1();printf("Board %d have %d important blanks for %d chessmen.\n", n, max2(), max1());n++;}return 0;
}
// 二分匹配
bool find(int x)
{// 遍历右侧元素for (int i = 1; i <= row; i++){// 判断有无边,是否被访问if (map[x][i] && !visit[i]){visit[i] = 1;if (!r[i] || find(r[i])){r[i] = x;return 1;}}}return 0;
}
// 求最大匹配数
int max1()
{int ans1 = 0;memset(r, 0, sizeof(r));for (int i = 1; i <= line; i++){memset(visit, 0, sizeof(visit));if (find(i))ans1++;}return ans1;
}
// 遍历删除并恢复所有边,求影响最大二分匹配的边
int max2()
{int tans = 0, point = 0;for (int j = 1; j <= line; j++){for (int i = 1; i <= row; i++){if (map[j][i]){tans = 0;map[j][i] = 0;tans = max1();map[j][i] = 1;if (tans < ans) point++;}}}return point;
}

http://www.lryc.cn/news/230605.html

相关文章:

  • SQL 主从数据库实时备份
  • C/C++:在#define中使用参数
  • Hive 查询优化
  • 【Java 进阶篇】JQuery 案例:优雅的隔行换色
  • Redis 常用的类型和 API
  • 在qt的设计师界面没有QVTKOpenGLWidget这个类,只有QOpenGLWidget,那么我们如何得到QVTKOpenGLWidget呢?
  • 力扣每日一道系列 --- LeetCode 138. 随机链表的复制
  • 无人零售:创新优势与广阔前景
  • 【华为OD题库-022】阿里巴巴找黄金宝箱(IV)-java
  • Linux 图形界面配置RAID
  • (脏读,不可重复读,幻读 ,mysql5.7以后默认隔离级别)、( 什么是qps,tps,并发量,pv,uv)、(什么是接口幂等性问题,如何解决?)
  • 安全通信网络(设备和技术注解)
  • 深度学习_12_softmax_图片识别优化版代码
  • element-ui设置下拉选择切换必填和非必填
  • Linux的命令——关于操作用户及用户组的命令
  • pycharm 设置多级跳转SSH
  • LeetCode 189.轮转数组(三种方法解决)
  • GB28181设备对接视频流的流程
  • 类属性修改(为什么python类不具备被赋值能力?)
  • uniapp App端 解决input@input事件动态修改值不生效的问题
  • ELK分布式日志
  • Kylin-Server-V10-SP3+Gbase+宝兰德信创环境搭建
  • po与vo互转工具类
  • 基于SpringBoot+Redis的前后端分离外卖项目-苍穹外卖(三)
  • PyCharm:2023新版PyCharm无UI工具栏,如何回旧版
  • 阿里云国际站:云备份
  • C#中.NET 6.0 Windows窗体应用通过EF访问数据库并对数据库追加、删除记录
  • kafka+ubuntu20.04+docker配置
  • 遍历一个对象,并得出所对应的值
  • WGCLOUD的特点整理