算法问题实战策略 PICNIC
下面是另一道搜索题目的解答过程
题目是《算法问题实战策略》中的一题
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的更多相关文章
- 《算法问题实战策略》-chaper7-穷举法
关于这一章节<算法实战策略>有一段概述问题,我认为对于编程人员来说非常有价值,故在这里进行如下的摘抄: 构想算法是很艰难的工作.相比大家都经历过,面对复杂的要求只是傻乎乎地盯着显示器,或者 ...
- 《算法问题实战策略》-chaper32-网络流
基本的网络流模型: 在图论这一块初步的应用领域中,两个最常见的关注点,其一时图中的路径长度,也就是我们常说的的最短路径问题,另一个则是所谓的“流问题”. 流问题的基本概念: 首先给出一张图. 其实所谓 ...
- 《算法问题实战策略》-chaper13-数值分析
这一章节主要介绍我们在进行数值分析常用的二分.三分和一个近似求解区间积分的辛普森法. 首先介绍二分. 其实二分的思想很好理解并且笔者在之前的一些文章中也有所渗透,对于二次函数甚至单元高次函数的零点求解 ...
- 《算法问题实战策略》——chaper9——动态规划法技巧
Q1: 数字游戏: 两个人(A.B)用n个整数排成的一排棋盘玩游戏,游戏从A开始,每个人有如下操作: (1) 拿走棋盘最右侧或者最左侧的棋子,被拿走的数字从棋盘中抹掉. (2) 棋盘中还剩 ...
- 《算法问题实战策略》-chaper8-动态规划法
Q1:偶尔在电视上看到一些被称为“神童”的孩子们背诵小数点以后几万位的圆周率.背诵这么长的数字,可利用分割数字的方法.我们用这种方法将数字按照位数不等的大小分割后再背诵. 分割形式如下: 所有数字都相 ...
- 《算法问题实战策略》-chaper21-树的实现和遍历
这一章节开始介绍一个数据结构中的一个基本概念——树. 我们从数据结构的解读来解释树结构的重要性,现实世界的数据除了最基本的线性结构(我们常用队列.数组和链表等结构表征),还有一个重要的特性——层级结构 ...
- 算法问题实战策略 QUADTREE
地址 https://algospot.com/judge/problem/read/QUADTREE 将压缩字符串还原后翻转再次压缩的朴素做法 在数据量庞大的情况下是不可取的 所以需要在压缩的情况下 ...
- 算法问题实战策略 DICTIONARY
地址 https://algospot.com/judge/problem/read/DICTIONARY 解法 构造一个26字母的有向图 判断无回路后 就可以输出判断出来的字符序了 比较各个字母的先 ...
- 算法问题实战策略 MEETINGROOM 附一份tarjan模板
地址 https://algospot.com/judge/problem/read/MEETINGROOM 解答 2-sat 代码样例过了 没有ac. 我又没有正确代码对拍..... 已确认是输出 ...
随机推荐
- 教你用python假装黑客装逼,当着朋友的面破解他的网站密码!
如何破解iphone登陆密码 今天看了一篇关于如何破解iphone手机密码的文章,瞬间觉得科学技术不是第一生产力,why? 根据“可靠消息”称,即便美国FBI也无法轻易的对iphone手机进行暴力破解 ...
- PHP 是如何做垃圾回收的
PHP 是如何做垃圾回收的 包含 php 5 与 php7 的变量实现和垃圾回收的对比 变量的实现 PHP 的变量是弱类型的,可以表示整数.浮点数.字符串等类型.PHP 的变量是使用结构体 zval ...
- spring cloud学习与思考——总起篇
接下来就spring cloud( Spring Boot 2.0版本)写一个系列,一方面加深记忆理解,做个日志,另一个方面,借这个方式跟朋友们沟通交流. 1.Spring boot是Spring的一 ...
- SSH框架之Spring第四篇
1.1 JdbcTemplate概述 : 它是spring框架中提供的一个对象,是对原始JdbcAPI对象的简单封装.spring框架为我们提供了很多的操作模板类. ORM持久化技术 模板类 JDBC ...
- 使用objc runtime实现iOS绿色的懒加载
使用objc runtime实现懒加载 地址:AutoPropertyCocoa 本文所指懒加载形式如下 - (id)lazyloadProperty{ if(_lazyloadProperty == ...
- Mysql 事务及其原理
Mysql 事务及其原理 什么是事务 什么是事务?事务是作为单个逻辑工作单元执行的一系列操作,通俗易懂的说就是一组原子性的 SQL 查询.Mysql 中事务的支持在存储引擎层,MyISAM 存储引擎不 ...
- 十分钟 CODING DevOps 全链路体验
近期 CODING 团队在 2019 KubeCon 大会上发布 DevOps 一站式解决方案:CODING 2.0.此次 CODING 全新上线了持续集成与制品库模块,通过自动化与标准化的方式来帮助 ...
- <String> 161 358
161. One Edit Distance 1. 两个字符串的长度之差大于1,直接返回False. 2. 两个字符串的长度之差等于1,长的那个字符串去掉一个字符,剩下的应该和短的字符串相同. 3. ...
- IT兄弟连 HTML5教程 HTML5的基本语法 小结及习题
小结 一个完整的HTML文件由标题.段落.列表.表格.文本,即嵌入的各种对象所组成,这些逻辑上统一的对象称为元素.HTML文档主体结构分为两部分,一部分是定义文档类型,另一部分则是定义文档主体的结构框 ...
- 关于Oracle数据库的rownum应用
它是Oracle系统顺序分配为从查询返回的行的编号,返回的第一行分配的是1,第二行是2,以此类推,这个伪字段可以用于限制查询返回的总行数,而且rownum不能以任何表的名称作为前缀. 如以下语句将无法 ...