哎哎...自己刚刚一看到这个题目居然。。。。。什么都想不到...看了一下别人的解题报告说最大匹配...于是就自己开始构思啦...

对于这个棋盘,有K个可以放棋子的位置....那么

首先我们开始可以求出这K个位置能放的最多棋子

这个就是最大匹配啦..一开始自己老是想不到怎么匹配....可以这样想,用这个棋盘的行与列匹配,因为车要不相互攻击,那么意味着每行每列只能放一个,一旦一个棋子放在了x , y坐标位置,那么第x行第y列就不能再放其他棋子,放了的这个棋子,就把x和y连成一条边...如果还是不理解可以看如下图(结合题目案例1)

那么现在可以知道可以放置的最多棋子就是最大二分匹配,我们先存为flag

然后就是处理重要点:

其实也比较简单,我们对于这K个点,一一考虑,去掉这个点,再求一次最大匹配,如果这次的最大匹配小于flag,那么可以知道,这个点就是重要点(可以考虑案例1,无论去掉哪一个点之后的最大匹配任然是2)

附上代码:一开始还担心会超时,但是居然没有,哎哎,不过看着题目排名,好多人都是0k 0ms。。。却不见一个人拿出来分享一下题解.....只给人留下羡慕的份

// 46MS 244K
#include<stdio.h>
#include<string.h> #define MAX 101 int N,M,K;
int node[MAX*MAX][2];//点先存起来,后面去点判断要用到node[i][0]表示第i个点的x坐标。node[i][1]表示第i个点的y坐标
bool map[MAX][MAX];//棋盘
int link[MAX];
bool useif[MAX]; bool dfs(int t)
{
for(int i=1;i<=M;i++)
{
if(!useif[i] && map[t][i])
{
useif[i]=true;
if(link[i]==-1 || dfs(link[i]))
{
link[i]=t;return true;
}
}
}
return false;
} int match()
{
int sum=0;
memset(link,-1,sizeof(link));
for(int i=1;i<=N;i++)
{
memset(useif,false,sizeof(useif));
if(dfs(i))
sum++;
}
return sum;
} int main()
{
int i;
int cas=1;
while(~scanf("%d%d%d",&N,&M,&K))
{
memset(map,0,sizeof(map));
for(i=0;i<K;i++)
{
scanf("%d%d",&node[i][0],&node[i][1]);
map[node[i][0]][node[i][1]]=1;
}
int flag=match();//首先匹配一次
int ans=0;
for(i=0;i<K;i++)
{
map[node[i][0]][node[i][1]]=0;//除去这个点
int x=match();
if(x!=flag)
ans++;
map[node[i][0]][node[i][1]]=1;//要记得吧点补回来
}
printf("Board %d have %d important blanks for %d chessmen.\n",cas++,ans,flag);
}
return 0;
}

图画的很烂...不要喷

总结:对于这类问题的转换思维还是狠狠不够...要努力

hdu1281结题报告的更多相关文章

  1. 《基于Arm实验箱的国密算法应用》课程设计 结题报告

    <基于Arm实验箱的国密算法应用>课程设计 结题报告 小组成员姓名:20155206赵飞 20155220吴思其 20155234昝昕明 指导教师:娄嘉鹏 设计方案 题目要求:基于Arm实 ...

  2. 《基于Cortex-M4的ucOS-III的应用》课程设计 结题报告

    <基于Cortex-M4的ucOS-III的应用>课程设计 结题报告 小组成员姓名:20155211 解雪莹 20155217 杨笛 20155227 辜彦霖 指导教师:娄嘉鹏 一.设计方 ...

  3. 2013山东省ICPC结题报告

    A.Rescue The Princess 已知一个等边三角形的两个顶点A.B,求第三个顶点C,A.B.C成逆时针方向. 常规的解题思路就是用已知的两个点列出x,y方程,但这样求出方程的解的表达式比较 ...

  4. uva401 - Palindromes结题报告

    题目地址 :  http://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&page=show_probl ...

  5. [置顶] 白话最小边覆盖总结--附加 hdu1151结题报告

    刚开始看到这个题目的时候就觉得想法很明了,就是不知道如何去匹配... 去网上看了不少人的解题报告,但是对于刚接触“最小边覆盖”的我来说....还是很困难滴....于是自己又开始一如以往学习“最大独立集 ...

  6. 有向图强连通分支的Tarjan算法讲解 + HDU 1269 连通图 Tarjan 结题报告

    题目很简单就拿着这道题简单说说 有向图强连通分支的Tarjan算法 有向图强连通分支的Tarjan算法伪代码如下:void Tarjan(u) {dfn[u]=low[u]=++index//进行DF ...

  7. 2016noipday1t1玩具迷题结题报告

    经常读这个代码有益于比赛时想起一些思路.... day1t1,洛谷dalao称之为水题...??然后我去年还是没拿到分,就这个,我还就写了40%的数据,AC到40,然而这不是关键,注释了freopen ...

  8. 2017 五一 清北学堂 Day1模拟考试结题报告

    预计分数:100+50+50 实际分数:5+50+100 =.= 多重背包 (backpack.cpp/c/pas) (1s/256M) 题目描述 提供一个背包,它最多能负载重量为W的物品. 现在给出 ...

  9. 结题报告:luogu P2014

    题目链接:P2014 选课 简单的树形\(dp\),借助\(dfs\)实现. 一般的树形\(dp\)数组是需要二维的,其中一维记录节点(编号或父/子节点的状态(有时三维)),另一维记录权值或计数. 重 ...

随机推荐

  1. 表单元素的submit()方法和onsubmit事件(转)

    1.表单元素中出现了name="submit"的元素 2.elemForm.submit();不会触发表单的onsubmit事件 3.动态创建表单时遇到的问题 表单元素拥有subm ...

  2. call和apply方法的理解

    第一种:直接先来个粟子吧... ; }   var child = {}; console.log(child); //Object() 对象 Parent.call(child); console. ...

  3. python自学笔记(一)简单了解python

    脚本解释型语言的内部机制 python先将脚本编译成字节码文件(pyc,pyo) python虚拟机解释并运行字节码文件 编译型语言的内部机制 先将源代码编译成机器码(机器能读懂的代码),生成可执行文 ...

  4. linux内核升级图文攻略

    Linux内核概览 Linux是一个一体化内核(monolithic kernel)系统. 设备驱动程序可以完全访问硬件. Linux内的设备驱动程序可以方便地以模块化(modularize)的形式设 ...

  5. 红外摄像头为什么使用850nm波长红外发射管

    市面上有很多不同波长的红外发射管,其中以850nm和940nm波长为主.那么红外摄像头为什么使用850nm波长红外发射管? 首先,我们来了解一下红外摄像头的相关知识.简单来说红外摄像头是用来感应红外线 ...

  6. SPOJ 8222 Substrings(后缀自动机)

    [题目链接] http://www.spoj.com/problems/NSUBSTR/ [题目大意] 给一个字符串S,令F(x)表示S的所有长度为x的子串中,出现次数的最大值. 求出所有的F. [题 ...

  7. 数据库 BUG:Illegal mix of collations (utf8_unicode_ci,IMPLICIT) and (utf8_general_ci,IMPLICIT) for operation '=

    在mysql5中遇到的问题: Illegal mix of collations (utf8_general_ci,IMPLICIT) and (utf8_unicode_ci,IMPLICIT) f ...

  8. nodejs - json序列化&反序列化示例

    // demo-json.js var obj = { "name": "LiLi", "age": 22, "sex" ...

  9. CentOS 6.4 U盘启动盘制作、安装及遇到的问题解决

    用UltraISO Premium Edition  9.3 制作的CentOS 6.4 U盘安装盘, 制作过程參考我写的百度经验:UltraISO制作U盘系统盘安装CentOS经验分享 安装时提示P ...

  10. Android Fragment 嵌套使用报错

    在新的SDK每次创建activity时,会自己主动生成  <pre name="code" class="java">public static c ...