CSP前模板复习
Tarjan 求强连通分量
展开查看
#include
#include
#include
using namespace std;
const int N = 1e4 + 1e3;
int n, m, cnt, dfn[N], low[N], inq[N];
int stk[N], tp, c[N], cnt_c, sz[N];
vector ed[N], ed_c[N];
void tarjan(int u) {
inq[u] = 1;
stk[++tp] = u;
dfn[u] = low[u] = ++cnt;
for (int i = 0, up = ed[u].size(); i < up; ++i) {
if (!dfn[ed[u][i]]) {
tarjan(ed[u][i]);
low[u] = min(low[u], low[ed[u][i]]);
}
else if (inq[ed[u][i]])
low[u] = min(low[u], low[ed[u][i]]);
}
if (dfn[u] == low[u]) {
++cnt_c;
while (1) {
c[stk[tp]] = cnt_c;
inq[stk[tp]] = 0;
sz[cnt_c]++;
tp--;
if (stk[tp + 1] == u) break;
}
}
}
int main()
{
scanf("%d%d", &n, &m);
for (int i = 1; i <= m; ++i) {
int u, v;
scanf("%d%d", &u, &v);
ed[u].push_back(v);
}
for (int i = 1; i <= n; ++i)
if (!dfn[i]) tarjan(i);
for (int i = 1; i <= n; ++i) {
for (int j = 0, up = ed[i].size(); j < up; ++j) {
if (c[i] != c[ed[i][j]]) {
ed_c[c[i]].push_back(c[ed[i][j]]);
}
}
}
int flag =0, ans = 0;
for (int i = 1; i <= cnt_c; ++i) {
if (!ed_c[i].size()) flag++, ans = sz[i];
}
if (flag > 1) return puts("0"), 0;
printf("%d\n", ans);
}
Tarjan 求点双联通分量
点击展开
#include <iostream>
#include <cstdio>
#include <algorithm>
#include <vector>
using namespace std;
const int N = 1e5 + 5;
int dfn[N], low[N], cnt, n, m;
int stk[N], tp, root, cut[N], cnt_DCC;
vector<int> ed[N], cut_node, DCC[N];
void tarjan(int u) {
int flag = 0;
dfn[u] = low[u] = ++ cnt;
stk[++tp] = u;
for (int i = 0, up = ed[u].size(); i < up; ++i) {
if (!dfn[ed[u][i]]) {
tarjan(ed[u][i]);
low[u] = min(low[u], low[ed[u][i]]);
if (low[ed[u][i]] >= dfn[u]) {
++flag;
if (root != u || flag > 1) {
cut[u] = 1;
}
++cnt_DCC;
while (1) {
DCC[cnt_DCC].push_back(stk[tp]);
tp--;
if (stk[tp + 1] == ed[u][i])
break;
}
DCC[cnt_DCC].push_back(u);
}
}
else
low[u] = min(low[u], dfn[ed[u][i]]);
}
}
int main()
{
scanf("%d%d", &n, &m);
for (int i = 1; i <= m; ++i) {
int u, v;
scanf("%d%d", &u, &v);
ed[u].push_back(v);
ed[v].push_back(u);
}
for (int i = 1; i <= n; ++i) if (!dfn[i])
tarjan(root = i);
for (int i = 1; i <= n; ++i)
if (cut[i]) cut_node.push_back(i);
printf("%d\n", (int)cut_node.size());
for (int i = 0, up = cut_node.size(); i < up; ++i)
printf("%d ", cut_node[i]);
puts("");
for (int i = 1; i <= cnt_DCC; ++i) {
printf("e-DCC %d ", i);
for (int j = 0, up = DCC[i].size(); j < up; ++j)
printf("%d ", DCC[i][j]);
puts("");
}
}
SPFA
展开
#include <iostream>
#include <cstdio>size=
#include <algorithm>
#include <cstring>
#include <queue>
using namespace std;
typedef long long LL;
const int N = 1e4 + 5, M = 1e6;
int head[N], tot, n, m, S, vis[N];
LL dis[N];
queue<int> que;
struct edge {
int nxt, to, w;
}e[M];
void add(int u, int v, int w) {
e[++tot].nxt = head[u];
e[tot].to = v;
e[tot].w = w;
head[u] = tot;
}
void SPFA() {
dis[S] = 0;
que.push(S);
for (int u; !que.empty(); ) {
u = que.front(); que.pop();
vis[u] = 0;
for (int i = head[u]; i; i = e[i].nxt) {
int nt = e[i].to;
if (dis[nt] > dis[u] + e[i].w) {
dis[nt] = dis[u] + e[i].w;
if (!vis[nt]) que.push(nt), vis[nt] = 1;
}
}
}
}
int main()
{
scanf("%d%d%d", &n, &m, &S);
for (int i = 1; i <= m; ++i) {
int u, v, w;
scanf("%d%d%d", &u, &v, &w);
add(u, v, w);
}
memset(dis, 120, sizeof(dis));
SPFA();
for (int i = 1; i <= n; ++i) {
if (dis[i] == dis[0])
printf("%lld ", 2147483647LL);
else printf("%lld ", dis[i]);
}
}
CSP前模板复习的更多相关文章
- CCF CSP 201509-3 模板生成系统
CCF计算机职业资格认证考试题解系列文章为meelo原创,请务必以链接形式注明本文地址 CCF CSP 201509-3 模板生成系统 问题描述 成成最近在搭建一个网站,其中一些页面的部分内容来自数据 ...
- wawawa8的模板复习计划
wawawa8的模板复习计划 数据结构 //手写堆 [link][https://www.luogu.org/problemnew/show/P3378] //并查集 [link][https://w ...
- NOIP前的模板复习和注意事项
联赛除去今天刚好只有一个星期了,最后一个星期也很关键,要吃好睡好保持心情愉悦.当然也免不了最后的复习计划. 首先是模板,之前还有很多模板没有复习到,这些东西是一定要落实到位的. 每天往后面写一点... ...
- SDOI2019 省选前模板整理
目录 计算几何✔ DP 斜率优化✔ 四边形不等式✔ 轮廓线DP✘ 各种分治 CDQ分治✔ 点分治✔ 整体二分✔ 数据结构 线段树合并✔ 分块✔ K-D Tree LCT 可持久化Trie✔ Splay ...
- 模板复习【updating】
马上就要noi了……可能滚粗已经稳了……但是还是要复习模板啊 LCT: bzoj2049 1A 7min # include <stdio.h> # include <string. ...
- [OI]省选前模板整理
省选前把板子整理一遍,如果发现有脑抽写错的情况,欢迎各位神犇打脸 :) 数学知识 数论: //组合数 //C(n,m) 在n个数中选m个的方案数 ll C[N][N]; void get_C(int ...
- noip模板复习
自己敲模板还是有很多容易错的地方 写在注释里面了 LCA #include<bits/stdc++.h> #define REP(i, a, b) for(register int i = ...
- CSP前的板子们
见窝的luogu博客qwq noip前的板子们
- CSP-S 赛前模板复习
快读模板 这个连算法都算不上... inline int read() { int x=0,f=1; char ch=getchar(); while(ch<'0' || ch>'9') ...
随机推荐
- TCP最大报文段长度MSS
最大报文段长度(MSS)表示TCP传往另一端的最大数据库的长度.当一个连接建立时,连接的双方都要通告各自需要接收的MSS选项(MSS选项只能出现在SYN报文段中).如果一方不接收来自另一方的MSS值, ...
- kentico中page alias的使用
这里设置的path or pattern,是针对于根目录而言的
- Python中导入类
python导入类与导入函数,模块基本一样,一个模块fun,其中包含三个类 class Dog(): def __init__(self,name): self.name=name def bark( ...
- 从浏览器地址栏输入url到显示页面的步骤
在浏览器地址栏输入URL 浏览器查看缓存,如果请求资源在缓存中并且新鲜,跳转到转码步骤 HTTP1.0提供Expires,值为一个绝对时间表示缓存新鲜日期 HTTP1.1增加了Cache-Cont ...
- [go]os.Open方法源码
file, err := os.Open("./buf.go") func Open(name string) (*File, error) { return OpenFile(n ...
- LC 406. Queue Reconstruction by Height
Suppose you have a random list of people standing in a queue. Each person is described by a pair of ...
- XML字符串和 java对象项目转换
这是之前写,仅供参考(如果缺少jar包可以私信我,CSDN现在下载的东西太费了,动不动就要积分,开源精神所剩无几了,也没办法都需要吃饭,可以理解) import javax.xml.bind.JAXB ...
- SAS数据挖掘实战篇【二】
SAS数据挖掘实战篇[二] 从SAS数据挖掘实战篇[一]介绍完目前的数据挖掘基本概念之外,对整个数据挖掘的概念和应用有初步的认识和宏观的把握之后,我们来了解一下SAS数据挖掘实战篇[二]SAS工具的应 ...
- 仿flash运动框架
github地址: [https://github.com/linxd5/pictureShow] PS: 新建一个github项目很简单,只要new一个repo,后面按照提示做就可以了~ 项目思路: ...
- SQLserver本地数据库开发
远程端数据库中生成脚本 注意 远程端的数据库 是中文版的还是英文版的,一般我们装的是英文版的, 如果远程端数据库是中文版的,那么我们本地的是英文版,在生成的脚本那需要修改,同时去除相应的路劲代码. 修 ...