LYDSY模拟赛day1 Tourist Attractions


/*
假设路径是 a − b − c − d,考虑枚举中间这条边 b − c,计
算有多少可行的 a 和 d。
设 degx 表示点 x 的度数,那么边 b − c 对答案的贡献为
(degb − 1)(degc − 1)− 经过 b − c 这条边的三元环个数。
计算三元环的个数只需要枚举除 b; c 之外的另一个点即可。
位运算优化
*/
#include<cstdio>
const int N=;
int cnt[],m,n,i,j,d[N];char g[N][N];long long ans;
int popcount(unsigned int x){return cnt[x>>]+cnt[x&];}
struct BIT{
unsigned int v[];
void set(int x){v[x>>]|=1U<<(x&);}
void count(const BIT&b){for(int i=;i<=m;i++)ans-=popcount(v[i]&b.v[i]);}
}f[N];
int main(){
freopen("tour.in","r",stdin);freopen("tour.out","w",stdout);
for(i=;i<;i++)cnt[i]=cnt[i>>]+(i&);
scanf("%d",&n);m=(n-)>>;
for(i=;i<n;i++){
scanf("%s",g[i]);
for(j=;j<n;j++)if(g[i][j]=='')f[i].set(j),d[i]++;
}
for(i=;i<n;i++)for(j=;j<i;j++)if(g[i][j]=='')ans+=(d[i]-)*(d[j]-),f[i].count(f[j]);
printf("%I64d",ans*);
fclose(stdin);fclose(stdout);
return ;
}
LYDSY模拟赛day1 Tourist Attractions的更多相关文章
- LYDSY模拟赛day1 String Master
		/* 暴力枚举两个后缀,计算最长能匹配多少前缀. 最优策略一定是贪心改掉前 k 个失配的字符. 时间复杂度 O(n3). */ #include<cstdio> ],b[]; int ma ... 
- LYDSY模拟赛day1 Walk
		/* 依旧考虑新增 2^20 个点. i 只需要向 i 去掉某一位的 1 的点连边. 这样一来图的边数就被压缩到了 20 · 2^20 + 2n + m,然后 BFS 求出 1 到每个点的最短路即可. ... 
- 队爷的讲学计划 CH Round #59 - OrzCC杯NOIP模拟赛day1
		题目:http://ch.ezoj.tk/contest/CH%20Round%20%2359%20-%20OrzCC杯NOIP模拟赛day1/队爷的讲学计划 题解:刚开始理解题意理解了好半天,然后发 ... 
- 队爷的Au Plan CH Round #59 - OrzCC杯NOIP模拟赛day1
		题目:http://ch.ezoj.tk/contest/CH%20Round%20%2359%20-%20OrzCC杯NOIP模拟赛day1/队爷的Au%20Plan 题解:看了题之后觉得肯定是DP ... 
- 队爷的新书 CH Round #59 - OrzCC杯NOIP模拟赛day1
		题目:http://ch.ezoj.tk/contest/CH%20Round%20%2359%20-%20OrzCC杯NOIP模拟赛day1/队爷的新书 题解:看到这题就想到了 poetize 的封 ... 
- CH Round #48 - Streaming #3 (NOIP模拟赛Day1)
		A.数三角形 题目:http://www.contesthunter.org/contest/CH%20Round%20%2348%20-%20Streaming%20%233%20(NOIP模拟赛D ... 
- CH Round #54 - Streaming #5 (NOIP模拟赛Day1)
		A.珠 题目:http://ch.ezoj.tk/contest/CH%20Round%20%2354%20-%20Streaming%20%235%20(NOIP模拟赛Day1)/珠 题解:sb题, ... 
- 10.17(山东多校联合模拟赛 day1)
		山东多校联合模拟赛 day1 题不难 rect [问题描述] 给出圆周上的 N 个点, 请你计算出以这些点中的任意四个为四个角,能构成多少个矩形. 点的坐标是这样描述的, 给定一个数组 v[1..N] ... 
- NOI模拟赛 Day1
		[考完试不想说话系列] 他们都会做呢QAQ 我毛线也不会呢QAQ 悲伤ING 考试问题: 1.感觉不是很清醒,有点困╯﹏╰ 2.为啥总不按照计划来!!! 3.脑洞在哪里 4.把模拟赛当作真正的比赛,紧 ... 
随机推荐
- 我也来谈一谈c++模板(一)
			c++中程序员使用模板能够写出与类型无关的代码,提高源代码重用,使用合适,大大提高了开发效率.此前,可以使用宏实现模板的功能,但是模板更加安全.清晰.在编写模板相关的代码是我们用到两个关键词:temp ... 
- ubuntu 下安装 texlive 并设置 ctex 中文套装
			1 安装 texlive2013 1.1 下载 texlive2013 下载地址:http://ftp.ctex.org/mirrors/CTAN/systems/texlive/Images/tex ... 
- c++适配器
			容器适配器是是标准库中通用的概念,包括容器适配器.迭代器适配器和函数适配器,本质上,适配器是使一种事物的行为类似于另一种事物的的行为的一种机制,容器适配器使一种已经存在的容器类型采用另一种不同的抽象类 ... 
- faster_rcnn c++版本的 caffe 封装(1)
			转载请注明出处,楼燚(yì)航的blog,http://www.cnblogs.com/louyihang-loves-baiyan/ 由于需要把FasterRCNN做的工程化,因此这里需要对Caff ... 
- 第3章 窗口与消息_3.1Windows编程模型
			第3章窗口与消息 3.1 Windows_编程模型 (1)窗口程序的运行过程 ①设计窗口 ②注册窗口类(RegisterClassEx).在注册之前,要先填写RegisterClassEx的参 ... 
- kettle运行spoon.bat时找不到javaw文件
			我也遇到这问题了,分享一下解决方法吧以后没准还有人能用到.我机器的主要问题是环境变量JAVA_HOME的值不对,应该写到jdk也就是C:\Program Files\Java\jdk1.7.0_25, ... 
- 搭建一套自己实用的.net架构(4)【CodeBuilder-RazorEngine】
			工欲善其事必先利其器, 下面来说说代码生成器. 现在代码生成器品种繁多各式各样, 什么codesmith.T4. 动软也算.那么每款代码生成器都有自己模板解析引擎. 现在比较流行的 NVelocit ... 
- 缩小窗口时CSS背景图出现右侧空白BUG的解决方法
			页面容器(#wrap)与页面头部(#header )为100%宽度.而内容的容器(#page)为固定宽度960px.浏览窗口缩小而小于内容层宽度时会产生宽度理解上的差异.如下图所示窗口宽度大于内容层宽 ... 
- VMware 设备VMnet0 上的网桥暂时关闭。此虚拟机无法与主机或网格中的其他计算机通信【转】
			今天克隆了一个win7的虚拟机,移动到我的本地.打开时发现虚拟机网格连接图标出现X断开连接,于是网上收了一堆答案无一个可用的,决定自己解决这个问题,解决过程如下: 1.报错图如下:设备VMnet0 上 ... 
- 1125MySQL Sending data导致查询很慢的问题详细分析
			-- 问题1 tablename使用主键索引反而比idx_ref_id慢的原因EXPLAIN SELECT SQL_NO_CACHE COUNT(id) FROM dbname.tbname FORC ... 
