关于HDU 5952的那些事
内容过后再贴,先发表一下心情和感悟。
这个题,我TLE了十多发,后来看了别人的题解,思路是一样的,他做了剪枝的我也做了,为何他的能过的我的超时?后来发现一个不是主要问题的问题:大家的图存储用的都是前向星式的写法,我的代码用的vector式的邻接表法,莫非vector很慢,导致超时?或者是我的代码写法结构和那个人的不一样,所以我的代码存在潜在的bug,说不定卡在哪个数据一直死循环了。然后把代码推倒重写,改成前向星式的写法,写好了,样例一测,直接过,提交一发,直接AC。我就不明白了,vector有这么慢吗?虽然之前也遇到卡vector的题,但vector也不至于慢太多呀,我始终想不明白呀。然后,再重新写了一个用vector存图的版本,dfs部分直接把前向星部分的复制过来,把边的扫描方式稍微改一改就OK了。样例一测,对了,提交一发,仍然AC。这下我就更不明白了,既然vector也能A,那说明不是vector的问题啊,莫非是我的第一个版本有死循环的bug?犹豫了一会,写了个测试数据生成器,生成一波大数据,把两个版本一跑,发现,版本三花了0.4s左右,版本一跑了蛮久,我以为是死递归了,准备关闭黑窗口时,跑完了,花了14s多。然后,我似乎明白了,版本一的某个地方花了太多时间,导致超时。对比一下两个版本,思路一模一样,代码结构略有不同,在保存答案那里,版本一用的是循环搜索得到的一组顶点解,用二进制位存储这些点,放到set集合中,让set自动去重。然后输出set的size。版本三是直接计数器加一,因为不存在重复。于是,我开始怀疑set了。虽说set的增删改查都是logN的时间复杂度,但是常数很大(也是听说的),莫非是这个常数大导致超时?仍然很疑惑啊,为何用set就这么慢。然后,我把版本三的记录答案也用了set,跑一下,花了12s多,差不多,仍然很慢,于是,我明白了,心里得到一个结论,set不要乱用,实在是慢。
———————————————————————————————————分割线——————————————————————————————————
过了几分钟后,发现,我记录答案的时候有个循环,对于每次的搜索结果,都要扫描一遍,最多10个,如果解有几千万个(完全有可能,如果N=32,M=1000,S=10),直接计数器加一可以不到1s完成任务,如果每个解都要循环10个顶点,那就要做几亿次循环,自然需要的时间就多了。所以,别小看这个“小循环”。
另外的话,想发表一下玩ACM的感悟。时间能快则快,哪怕是多一次无用的循环,能优化则优化。怎么快怎么写,速度快就是王道。比如:
;i < n;++i))flag = true;
这就是为了追求代码简介和优雅,牺牲了时间。如果是这种情况,还是要纠正习惯,改为这样,哪怕代码多点。
;i < n;++i){
){
flag = true;
break;
}
}
其次,在保证时间足够快的基础上,对于编码来说,怎么快怎么写,不要去考虑变量命名是否规范、代码是否整洁之类的,ACM里面不搞这一套。过了就是王道,否则,没过的话,一切都是瞎扯淡。没用的。当然,能保证代码简介和整洁哪自然最好,保证不了也没关系。比如:
;i = tree[i].next)
while(scanf("%d", &n) != EOF)
直接这样就好了:
for(i = head[root];~i;i = tree[i].next)
while(~scanf("%d", &n))
当然,这种技巧还有很多,哪次找个时间统一做个总结。这里先这样吧。
关于HDU 5952的那些事的更多相关文章
- HDU - 5952 Counting Cliques
Counting Cliques HDU - 5952 OJ-ID: hdu-5952 author:Caution_X date of submission:20191110 tags:dfs,gr ...
- HDU 5952 Counting Cliques 【DFS+剪枝】 (2016ACM/ICPC亚洲区沈阳站)
Counting Cliques Time Limit: 8000/4000 MS (Java/Others) Memory Limit: 65536/65536 K (Java/Others) ...
- HDU 5952 [DFS]
题目链接:[http://acm.hdu.edu.cn/showproblem.php?pid=5952] 题意:给出一张无向图,然后判断这张图中一共有多少个不同的大小为S的完全图,并且保证每个点的度 ...
- Counting Cliques HDU - 5952 单向边dfs
题目:题目链接 思路:这道题vj上Time limit:4000 ms,HDU上Time Limit: 8000/4000 MS (Java/Others),且不考虑oj测评机比现场赛慢很多,但10月 ...
- 注意题目条件!!! 团问题 HDU 5952
题目大意:团的定义就是,团内的所有点,两两之间各有一条边,团的大小就是点的个数.现给你一个n个点,m条边的图.问,该图中有多少点的个数为s的团. (题目保证每个点的度数不超过20,n<=100, ...
- hdu 5952 连通子图
Counting Cliques Time Limit: 8000/4000 MS (Java/Others) Memory Limit: 65536/65536 K (Java/Others) ...
- HDU - 5952 Counting Cliques(DFS)
A clique is a complete graph, in which there is an edge between every pair of the vertices. Given a ...
- hdu 5952 Counting Cliques 求图中指定大小的团的个数 暴搜
题目链接 题意 给定一个\(n个点,m条边\)的无向图,找出其中大小为\(s\)的完全图个数\((n\leq 100,m\leq 1000,s\leq 10)\). 思路 暴搜. 搜索的时候判断要加进 ...
- HDU - 5952 Counting Cliques(dfs搜索)
题目: A clique is a complete graph, in which there is an edge between every pair of the vertices. Give ...
随机推荐
- Gym - 100676H H. Capital City (边双连通分量缩点+树的直径)
https://vjudge.net/problem/Gym-100676H 题意: 给出一个n个城市,城市之间有距离为w的边,现在要选一个中心城市,使得该城市到其余城市的最大距离最短.如果有一些城市 ...
- Nginx 正则匹配
目录 Nginx 正则表达式之匹配操作符 过期缓存 针对浏览器 针对文件类型 针对文件夹 判断文件,文件夹 设置某些类型文件的浏览器缓存时间 匹配到所有uri 全局变量 常用正则 Nginx 正则表达 ...
- $.proxy用法详解
jQuery中的$.proxy官方描述为: 描述:接受一个函数,然后返回一个新函数,并且这个新函数始终保持了特定的上下文语境. 官方API: jQuery.proxy( function, conte ...
- Rails Guide--Working with JavaScript in Rails; 如何把jquery转化为原生js
1 An Introduction to Ajax 打开网页的的过程也叫:request response cycel. JavaScript也可以request然后parse the respons ...
- 2-12-配置squid代理服务器加快网站访问速度
本节所讲内容: squid服务器常见概念 squid服务器安装及相关配置文件 实战:配置squid正向代理服务器 实战:配置透明squid代理提升访问速度 实战:配置squid反向代理加速度内网web ...
- poj2159
题解: 记录一下每个串每个字母出现的次数 排序 然后看看是否相等 代码: #include<cstdio> #include<cstring> #include<cstr ...
- 如果从码云上git clone项目
1.本地找个文件夹右击选择 git base 2.输入地址 弹出一个窗口 需要输入用户名.密码(就是码云的登录名.密码) 3.完成
- iOS笔记之文件读写
最近做的项目中要存储一组图片数据,图片带有name,date等属性,处理办法是讲image图片直接存在沙盒documents文件中,再使用plist文件存储图片属性和image路径. 存入图片: - ...
- Ubuntu 16.04系统开机紫屏的解决办法
具体症状为卡在开机界面,按任何键都无反应. 网上查看了几篇文章 ,如下: 解决:ubuntu16.04启动时长时间停留在紫屏或跳文本的黑屏界面 Ubuntu16.04显卡驱动 电源管理 里面提到的开机 ...
- ubuntu16 Intellij Idea Install&config
1,下载idea二进制文件,有免费和不免费的. https://www.jetbrains.com/idea/download/#section=linux 2,解压下载文件. tar -xvzf . ...