BZOJ 4304 tarjan+topsort+bitset】的更多相关文章

我就是想骗一骗访问量 先Tarjan搞出来所有的强连通分量 正向连边 反向连边 topsort一发  搞出来每个点可以到哪些点 和哪些点可以到这个点 对于每条边 与一下  就是答案 //By SiriusRen #include <bits/stdc++.h> using namespace std; ,M=N*N; ; int low[N],dfn[N],cnt,stk[N],vis[N],p[N],top; set<int>s; struct Edge{ bitset<N…
题目链接 先缩点,对于scc之间贡献即为szscc[i]*szscc[j] 用f[i][j]表示scci是否能到sccj 拓扑排序,每次把now的f或上to的f 用bitset优化 //63888kb 1080ms #include <cstdio> #include <cctype> #include <bitset> #include <algorithm> #define gc() getchar() const int N=2005,M=4e6+5;…
Solution 简单的$Tarjan$题. 有大佬现成博客 就不写了 → 传送门 Code #include<cstdio> #include<cstring> #include<algorithm> #include<queue> #define rd read() using namespace std; ; ; int n, m; int head[N], tot, Head[N], Tot; int low[N], dfn[N], cnt; int…
UVA11324 The Largest Clique 题目描述 给你一张有向图 \(G\),求一个结点数最大的结点集,使得该结点集中的任意两个结点 \(u\) 和 \(v\) 满足:要么 \(u\) 可以达 \(v\),要么 \(v\) 可以达 \(u\)(\(u,v\)相互可达也行). 输入输出格式 输入格式: 第一行:测试数据组数\(T\),每组数据的格式如下: 第一行为结点数 \(n\) 和边数 \(m\) ,结点编号 \(1-n\). 以下\(m\)行每行两个整数 \(u\) 和 \(…
Description 给定一个n个点m条边有向图,每个点有一个权值,求一条路径,使路径经过的点权值之和最大.你只需要求出这个权值和. 允许多次经过一条边或者一个点,但是,重复经过的点,权值只计算一次. Input 第一行,n,m 第二行,n个整数,依次代表点权 第三至m+2行,每行两个整数u,v,表示u->v有一条有向边 Output 共一行,最大的点权之和. 缩点+DP这是题目说的 先缩点,对于每一个联通块之间建边,这时得到一张\(DAG\)(有向无环图) 我们对其跑拓扑排序,然后开一个数组…
题目描述 输入格式 输入数据第一行是图顶点的数量,一个正整数N. 接下来N行,每行N个字符.第i行第j列的1表示顶点i到j有边,0则表示无边. 输出格式 输出一行一个整数,表示该图的连通数. 样例 样例输入 3 010 001 100 样例输出 9 数据范围与提示 对于100%的数据,N不超过2000. solution: 这道题给出三种算法: DFS: 这道题搜索可以过 用vecter建边,若有一条由i指向j的边,那么把j压到i的vector中(这种建边方法好像比前向星快) 建立bool数组v…
题意 给定一个正整数集,求所有子集算术和的异或和   题解 每次加入一个元素x,用原集合a xor (a<< x) 然后每一个值统计一下 bitset看起来很优越,是一个能位运算的布尔数组 #include<bitset> #include<stdio.h> int n,sum,ans; using namespace std; bitset<>a; int main(){ scanf("%d",&n); a[]=; ;i<…
3687: 简单题 Time Limit: 10 Sec  Memory Limit: 512 MB[Submit][Status][Discuss] Description 小呆开始研究集合论了,他提出了关于一个数集四个问题: 1.子集的异或和的算术和. 2.子集的异或和的异或和. 3.子集的算术和的算术和. 4.子集的算术和的异或和.     目前为止,小呆已经解决了前三个问题,还剩下最后一个问题还没有解决,他决定把 这个问题交给你,未来的集训队队员来实现. Input 第一行,一个整数n.…
题目:https://www.lydsy.com/JudgeOnline/problem.php?id=3687 关于 bitset :https://blog.csdn.net/snowy_smile/article/details/79120063 https://blog.csdn.net/liushu1231/article/details/8844631 不知为何,上面的可以 A ,下面的会 WA . #include<cstdio> #include<cstring>…
#include<bits/stdc++.h> #define LL long long #define fi first #define se second #define mk make_pair #define pii pair<int,int> #define piii pair<int, pair<int,int> > using namespace std; ; + ; const int inf = 0x3f3f3f3f; const LL I…