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') ...
随机推荐
- JavaScript 高级系列之节流 [throttle] 与防抖 [debounce]
一.概念 这两个东西都是为了项目优化而出现的,官方是没有具体定义的,他们的出现主要是为了解决一些短时间内连续执行的事件带来性能上的不佳和内存的消耗巨大等问题:像这类事件一般像 scroll keyup ...
- C++入门经典-例8.3-子类显示调用父类构造函数
1:当父类含有带参数的构造函数时,创建子类的时候会调用它吗?答案是通过显示方式才可以调用. 无论创建子类对象时调用的是那种子类构造函数,都会自动调用父类默认构造函数.若想使用父类带参数的构造函数,则需 ...
- 黑马vue---14、v-model双向绑定
黑马vue---14.v-model双向绑定 一.总结 一句话总结: 1.v-bind 只能实现数据的单向绑定,从 M 自动绑定到 V, 无法实现数据的双向绑定 2.v-model 指令,可以实现 表 ...
- 为什么有些应用非VxWorks不可
实时操作系统(RTOS)是专用于对时间精确度敏感的操作系统.典型的情况是,这种应用需要从传感器收集数据.做出分析并对关键性设备进行控制,例如飞机.列车.手术刀.这类控制必须精准,不容许出现 ...
- omniplan
汉化版安装包 下载链接:https://pan.baidu.com/s/104ZddPtNWTHyEMZx90agKw 密码:qizl 序列号 Name: Appked Serial: I ...
- 如何修改phpstorm的缓存目录
相信使用phpstorm的人们都被缓存目录的大小困扰过.怎么修改到其它地方呢? 1. 找到 idea.properties 文件,配置信息都在此文件中,F:\Program Files\JetBrai ...
- WebStrom编程小技巧--HTML快速创建指定id或者类名的div
打印div标签快速方法:“先打出#yz,然后Tab键补全即可获得<div id="yz"></div>同理:我们也可以先打出“.tz"然后Tab键 ...
- windows实用cmd命令总结
D: 进入D盘 cd D:\eclipse 进入D盘后进入D盘下的某个路径 Ipconfig 查看计算机ip Cls 清空命令行 ping ip(主机名) 测试网络是否畅通 Help 查看所有的d ...
- java web 开发三剑客 -------电子书
Internet,人们通常称为因特网,是当今世界上覆盖面最大和应用最广泛的网络.根据英语构词法,Internet是Inter + net,Inter-作为前缀在英语中表示“在一起,交互”,由此可知In ...
- appium+python+android+HTMLTestRunner使用过程中的问题
1:问:appium客户端刚发布了一版新的,我想升级可以吗?答:建议对于刚发布的新版本不要立即升级,因为客户端每升级一版它肯定会去增加和删减一些语句.所以不建议立即升级. 应该先采取调研的态度看 ...