下面是另一道搜索题目的解答过程
题目是《算法问题实战策略》中的一题
oj地址是韩国网站 连接比较慢 https://algospot.com/judge/problem/read/PICNIC
大意如下

输入

输出

也是上来就撸一把DFS
全部能够匹配完成则计数增加1
但是有很多重复计算
我试过记录关系对的时候 以数值大小为序 只能排除一部分重复计算
错误的代码:

 #include <iostream>
#include <vector>
#include <algorithm> using namespace std; /*
3
2 1
0 1
4 6
0 1 1 2 2 3 3 0 0 2 1 3
6 10
0 1 0 2 1 2 1 3 1 4 2 3 2 4 3 4 3 5 4 5
//====================================
1
3
4
*/ int t;
int a, b;
int n, m;
typedef pair<int, int> PII; bool isFriend(int i, int j, const vector<PII>& friendv)
{
int minIdx = min(i, j);
int maxIdx = max(i, j); for (auto& e : friendv) {
if (e.first == minIdx && e.second == maxIdx)
return true;
} return false;
} int dfs(bool isChecked[],const vector<PII>& friendv)
{
int firstFree = -;
for (int i = ; i < n; i++) {
if (isChecked[i] == false){
firstFree = i;
break;
}
} if (- == firstFree)
return ; int ret = ; for (int secondFree = firstFree + ; secondFree < n; secondFree++) {
if (firstFree != secondFree && isChecked[firstFree] == false && isChecked[secondFree] == false
&& isFriend(firstFree, secondFree, friendv)) {
isChecked[firstFree] = true; isChecked[secondFree] = true;
ret += dfs(isChecked, friendv);
isChecked[firstFree] = false; isChecked[secondFree] = false;
}
} return ret;
} int main()
{
cin >> t; while (t--) {
cin >> n >> m;
vector<PII> friendv;
bool isChecked[] = {false};
while (m--) {
cin >> a >> b;
friendv.push_back({min(a,b),max(a,b)});
}
sort(friendv.begin(), friendv.end());
cout << dfs(isChecked, friendv);
} return ;
}

经过调试 发现DFS中双重循环有很大问题
i=0时候检测出 0 1配对 然后检测出2 3 配对.
但是当i=2时 也能检测2 3 配对 以及 0 1 配对。

于是做了以下修改,解决重复问题
ac代码

 #include <iostream>
#include <vector>
#include <algorithm> using namespace std; /*
3
2 1
0 1
4 6
0 1 1 2 2 3 3 0 0 2 1 3
6 10
0 1 0 2 1 2 1 3 1 4 2 3 2 4 3 4 3 5 4 5
//====================================
1
3
4
*/ int t;
int a, b;
int n, m;
typedef pair<int, int> PII; bool isFriend(int i, int j, const vector<PII>& friendv)
{
int minIdx = min(i, j);
int maxIdx = max(i, j); for (auto& e : friendv) {
if (e.first == minIdx && e.second == maxIdx)
return true;
} return false;
} int dfs(bool isChecked[],const vector<PII>& friendv)
{
int firstFree = -;
for (int i = ; i < n; i++) {
if (isChecked[i] == false){
firstFree = i;
break;
}
} if (- == firstFree)
return ; int ret = ; for (int secondFree = firstFree + ; secondFree < n; secondFree++) {
if (firstFree != secondFree && isChecked[firstFree] == false && isChecked[secondFree] == false
&& isFriend(firstFree, secondFree, friendv)) {
isChecked[firstFree] = true; isChecked[secondFree] = true;
ret += dfs(isChecked, friendv);
isChecked[firstFree] = false; isChecked[secondFree] = false;
}
} return ret;
} int main()
{
cin >> t; while (t--) {
cin >> n >> m;
vector<PII> friendv;
bool isChecked[] = {false};
while (m--) {
cin >> a >> b;
friendv.push_back({min(a,b),max(a,b)});
}
sort(friendv.begin(), friendv.end());
cout << dfs(isChecked, friendv)<<endl;
} return ;
}

算法问题实战策略 PICNIC的更多相关文章

  1. 《算法问题实战策略》-chaper7-穷举法

    关于这一章节<算法实战策略>有一段概述问题,我认为对于编程人员来说非常有价值,故在这里进行如下的摘抄: 构想算法是很艰难的工作.相比大家都经历过,面对复杂的要求只是傻乎乎地盯着显示器,或者 ...

  2. 《算法问题实战策略》-chaper32-网络流

    基本的网络流模型: 在图论这一块初步的应用领域中,两个最常见的关注点,其一时图中的路径长度,也就是我们常说的的最短路径问题,另一个则是所谓的“流问题”. 流问题的基本概念: 首先给出一张图. 其实所谓 ...

  3. 《算法问题实战策略》-chaper13-数值分析

    这一章节主要介绍我们在进行数值分析常用的二分.三分和一个近似求解区间积分的辛普森法. 首先介绍二分. 其实二分的思想很好理解并且笔者在之前的一些文章中也有所渗透,对于二次函数甚至单元高次函数的零点求解 ...

  4. 《算法问题实战策略》——chaper9——动态规划法技巧

    Q1: 数字游戏: 两个人(A.B)用n个整数排成的一排棋盘玩游戏,游戏从A开始,每个人有如下操作: (1)    拿走棋盘最右侧或者最左侧的棋子,被拿走的数字从棋盘中抹掉. (2)    棋盘中还剩 ...

  5. 《算法问题实战策略》-chaper8-动态规划法

    Q1:偶尔在电视上看到一些被称为“神童”的孩子们背诵小数点以后几万位的圆周率.背诵这么长的数字,可利用分割数字的方法.我们用这种方法将数字按照位数不等的大小分割后再背诵. 分割形式如下: 所有数字都相 ...

  6. 《算法问题实战策略》-chaper21-树的实现和遍历

    这一章节开始介绍一个数据结构中的一个基本概念——树. 我们从数据结构的解读来解释树结构的重要性,现实世界的数据除了最基本的线性结构(我们常用队列.数组和链表等结构表征),还有一个重要的特性——层级结构 ...

  7. 算法问题实战策略 QUADTREE

    地址 https://algospot.com/judge/problem/read/QUADTREE 将压缩字符串还原后翻转再次压缩的朴素做法 在数据量庞大的情况下是不可取的 所以需要在压缩的情况下 ...

  8. 算法问题实战策略 DICTIONARY

    地址 https://algospot.com/judge/problem/read/DICTIONARY 解法 构造一个26字母的有向图 判断无回路后 就可以输出判断出来的字符序了 比较各个字母的先 ...

  9. 算法问题实战策略 MEETINGROOM 附一份tarjan模板

    地址 https://algospot.com/judge/problem/read/MEETINGROOM 解答  2-sat 代码样例过了 没有ac. 我又没有正确代码对拍..... 已确认是输出 ...

随机推荐

  1. ASP.NET MVC5基础-过滤器(Filters)详解

    什么是过滤器? 过滤器的类型与作用 定义过滤器 授权过滤器 动作过滤器 结果过滤器 异常处理过滤器 过滤器的使用方法 总结 什么是过滤器? 通过上一篇关于Controller控制器的文章我们知道,MV ...

  2. C#中PadLeft,PadRight的用法

    今天在遇到一个需求的时候,需要一个字符串实现自增.是根据数据库中一个自增的int类型的值,实现自增的.但是要加上前缀.比如,数据库中有一个自增的值,为,2.那么这个自增的值后面的值就位3.4.5.6. ...

  3. html5的 history模式和hash模式

    直观区别 hash 带一个# history 没有# 各自特点 hash: 仅 hash 符号之前的内容会被包含在请求中,**因此对于后端来说,即使没有做到对路由的全覆盖,也不会返回 404 错误.* ...

  4. Android Fragment 多层叠加时点击穿透解决方案

    一.问题现象 多层fragment叠加时,点击上层fragment会使下层fragment的控件对应点击事件响应,这种现象就是点击穿透. 对于这种情况,我们一般都是对baseFragment进行vie ...

  5. Android-再次解读萤石云视频

    ### 前言 我之前写过一篇萤石云的集成文章,很多人问我有没有demo, 今天我再次总结一下, 并加个些功能. - 集成步骤 - 视频预览播放 - 视频放大缩小 - 视频的质量切换 - 截图 - 视频 ...

  6. JQuery 实现多个checkbox 只选中一个

    <!DOCTYPE HTML> <html> <head> <meta http-equiv="Content-Type" content ...

  7. MHA在监控和故障转移时都做了什么

    转自 https://blog.csdn.net/ashic/article/details/75645479 以下是MHA(masterha_manager)在监控和故障切换上的基本流程 验证复制配 ...

  8. Linux系统学习 二十二、SAMBA服务—Samba基本使用—share权限访问、客户端的使用

    share权限访问 配置文件修改 [global]全局设置 workgroup=MYGROUP server string=Samba Server Lamp log file=/var/log/sa ...

  9. cordova+vue混合式开发App

    应要求第一次使用cordova打包了一下vue写的app项目,期间遇到了不少问题,整理一下流程并记录一下常见问题吧.        cordova打包项目需要的环境配置啥的就不具体讲啦,百度一下很多教 ...

  10. SA详细注释不压行代码

    ){ //变量含义:m是字符集大小,n是字符串长度,c是一个桶数组,a[i]是字符串(下标从1开始) //rk[i]就是suffix(i)的字典序排名,sa[i]就是要求的排名为i的后缀的起始位置,即 ...