内容过后再贴,先发表一下心情和感悟。

这个题,我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的那些事的更多相关文章

  1. HDU - 5952 Counting Cliques

    Counting Cliques HDU - 5952 OJ-ID: hdu-5952 author:Caution_X date of submission:20191110 tags:dfs,gr ...

  2. HDU 5952 Counting Cliques 【DFS+剪枝】 (2016ACM/ICPC亚洲区沈阳站)

    Counting Cliques Time Limit: 8000/4000 MS (Java/Others)    Memory Limit: 65536/65536 K (Java/Others) ...

  3. HDU 5952 [DFS]

    题目链接:[http://acm.hdu.edu.cn/showproblem.php?pid=5952] 题意:给出一张无向图,然后判断这张图中一共有多少个不同的大小为S的完全图,并且保证每个点的度 ...

  4. Counting Cliques HDU - 5952 单向边dfs

    题目:题目链接 思路:这道题vj上Time limit:4000 ms,HDU上Time Limit: 8000/4000 MS (Java/Others),且不考虑oj测评机比现场赛慢很多,但10月 ...

  5. 注意题目条件!!! 团问题 HDU 5952

    题目大意:团的定义就是,团内的所有点,两两之间各有一条边,团的大小就是点的个数.现给你一个n个点,m条边的图.问,该图中有多少点的个数为s的团. (题目保证每个点的度数不超过20,n<=100, ...

  6. hdu 5952 连通子图

    Counting Cliques Time Limit: 8000/4000 MS (Java/Others)    Memory Limit: 65536/65536 K (Java/Others) ...

  7. 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 ...

  8. hdu 5952 Counting Cliques 求图中指定大小的团的个数 暴搜

    题目链接 题意 给定一个\(n个点,m条边\)的无向图,找出其中大小为\(s\)的完全图个数\((n\leq 100,m\leq 1000,s\leq 10)\). 思路 暴搜. 搜索的时候判断要加进 ...

  9. HDU - 5952 Counting Cliques(dfs搜索)

    题目: A clique is a complete graph, in which there is an edge between every pair of the vertices. Give ...

随机推荐

  1. Gym - 100676H H. Capital City (边双连通分量缩点+树的直径)

    https://vjudge.net/problem/Gym-100676H 题意: 给出一个n个城市,城市之间有距离为w的边,现在要选一个中心城市,使得该城市到其余城市的最大距离最短.如果有一些城市 ...

  2. Nginx 正则匹配

    目录 Nginx 正则表达式之匹配操作符 过期缓存 针对浏览器 针对文件类型 针对文件夹 判断文件,文件夹 设置某些类型文件的浏览器缓存时间 匹配到所有uri 全局变量 常用正则 Nginx 正则表达 ...

  3. $.proxy用法详解

    jQuery中的$.proxy官方描述为: 描述:接受一个函数,然后返回一个新函数,并且这个新函数始终保持了特定的上下文语境. 官方API: jQuery.proxy( function, conte ...

  4. Rails Guide--Working with JavaScript in Rails; 如何把jquery转化为原生js

    1 An Introduction to Ajax 打开网页的的过程也叫:request response cycel. JavaScript也可以request然后parse the respons ...

  5. 2-12-配置squid代理服务器加快网站访问速度

    本节所讲内容: squid服务器常见概念 squid服务器安装及相关配置文件 实战:配置squid正向代理服务器 实战:配置透明squid代理提升访问速度 实战:配置squid反向代理加速度内网web ...

  6. poj2159

    题解: 记录一下每个串每个字母出现的次数 排序 然后看看是否相等 代码: #include<cstdio> #include<cstring> #include<cstr ...

  7. 如果从码云上git clone项目

    1.本地找个文件夹右击选择 git base 2.输入地址 弹出一个窗口 需要输入用户名.密码(就是码云的登录名.密码) 3.完成

  8. iOS笔记之文件读写

    最近做的项目中要存储一组图片数据,图片带有name,date等属性,处理办法是讲image图片直接存在沙盒documents文件中,再使用plist文件存储图片属性和image路径. 存入图片: - ...

  9. Ubuntu 16.04系统开机紫屏的解决办法

    具体症状为卡在开机界面,按任何键都无反应. 网上查看了几篇文章 ,如下: 解决:ubuntu16.04启动时长时间停留在紫屏或跳文本的黑屏界面 Ubuntu16.04显卡驱动 电源管理 里面提到的开机 ...

  10. ubuntu16 Intellij Idea Install&config

    1,下载idea二进制文件,有免费和不免费的. https://www.jetbrains.com/idea/download/#section=linux 2,解压下载文件. tar -xvzf . ...