C/C++,图算法——求强联通的Tarjan算法之源程序

1 文本格式

#include <bits/stdc++.h>

using namespace std;

const int maxn = 1e4 + 5;

const int maxk = 5005;

int n, k;

int idmaxn5;

char smaxn55, ansmaxk;

bool vismaxn;

struct Edge {

int v, nxt;

} emaxn \* 100;

int headmaxn, tot = 1;

void addedge(int u, int v) {

etot.v = v;

etot.nxt = headu;

headu = tot++;

}

int dfnmaxn, lowmaxn, colormaxn, stkmaxn, insmaxn, top, dfs_clock, c;

void tarjan(int x) { // tarjan算法求强联通

stk++top = x;

insx = 1;

dfnx = lowx = ++dfs_clock;

for (int i = headx; i; i = ei.nxt) {

int v = ei.v;

if (!dfnv) {

tarjan(v);

lowx = min(lowx, lowv);

} else if (insv)

lowx = min(lowx, dfnv);

}

if (dfnx == lowx) {

c++;

do {

colorstk\[top] = c;

insstk\[top] = 0;

} while (stktop-- != x);

}

}

int main() {

scanf("%d %d", &k, &n);

for (int i = 1; i <= n; i++) {

for (int j = 1; j <= 3; j++) scanf("%d%s", &idij, sij);

for (int j = 1; j <= 3; j++) {

for (int k = 1; k <= 3; k++) {

if (j == k) continue;

int u = 2 * idij - (sij0 == 'B');

int v = 2 * idik - (sik0 == 'R');

addedge(u, v);

}

}

}

for (int i = 1; i <= 2 * k; i++)

if (!dfni) tarjan(i);

for (int i = 1; i <= 2 * k; i += 2)

if (colori == colori + 1) {

puts("-1");

return 0;

}

for (int i = 1; i <= 2 * k; i += 2) {

int f1 = colori, f2 = colori + 1;

if (visf1) {

ans(i + 1) \>\> 1 = 'R';

continue;

}

if (visf2) {

ans(i + 1) \>\> 1 = 'B';

continue;

}

if (f1 < f2) {

visf1 = 1;

ans(i + 1) \>\> 1 = 'R';

} else {

visf2 = 1;

ans(i + 1) \>\> 1 = 'B';

}

}

ansk + 1 = 0;

printf("%s\n", ans + 1);

return 0;

}

2 代码格式

cpp 复制代码
#include <bits/stdc++.h>
using namespace std;
const int maxn = 1e4 + 5;
const int maxk = 5005;

int n, k;
int id[maxn][5];
char s[maxn][5][5], ans[maxk];
bool vis[maxn];

struct Edge {
  int v, nxt;
} e[maxn * 100];

int head[maxn], tot = 1;

void addedge(int u, int v) {
  e[tot].v = v;
  e[tot].nxt = head[u];
  head[u] = tot++;
}

int dfn[maxn], low[maxn], color[maxn], stk[maxn], ins[maxn], top, dfs_clock, c;

void tarjan(int x) {  // tarjan算法求强联通
  stk[++top] = x;
  ins[x] = 1;
  dfn[x] = low[x] = ++dfs_clock;
  for (int i = head[x]; i; i = e[i].nxt) {
    int v = e[i].v;
    if (!dfn[v]) {
      tarjan(v);
      low[x] = min(low[x], low[v]);
    } else if (ins[v])
      low[x] = min(low[x], dfn[v]);
  }
  if (dfn[x] == low[x]) {
    c++;
    do {
      color[stk[top]] = c;
      ins[stk[top]] = 0;
    } while (stk[top--] != x);
  }
}

int main() {
  scanf("%d %d", &k, &n);
  for (int i = 1; i <= n; i++) {
    for (int j = 1; j <= 3; j++) scanf("%d%s", &id[i][j], s[i][j]);

    for (int j = 1; j <= 3; j++) {
      for (int k = 1; k <= 3; k++) {
        if (j == k) continue;
        int u = 2 * id[i][j] - (s[i][j][0] == 'B');
        int v = 2 * id[i][k] - (s[i][k][0] == 'R');
        addedge(u, v);
      }
    }
  }

  for (int i = 1; i <= 2 * k; i++)
    if (!dfn[i]) tarjan(i);

  for (int i = 1; i <= 2 * k; i += 2)
    if (color[i] == color[i + 1]) {
      puts("-1");
      return 0;
    }

  for (int i = 1; i <= 2 * k; i += 2) {
    int f1 = color[i], f2 = color[i + 1];
    if (vis[f1]) {
      ans[(i + 1) >> 1] = 'R';
      continue;
    }
    if (vis[f2]) {
      ans[(i + 1) >> 1] = 'B';
      continue;
    }
    if (f1 < f2) {
      vis[f1] = 1;
      ans[(i + 1) >> 1] = 'R';
    } else {
      vis[f2] = 1;
      ans[(i + 1) >> 1] = 'B';
    }
  }
  ans[k + 1] = 0;
  printf("%s\n", ans + 1);
  return 0;
}
相关推荐
Tina学编程8 分钟前
[HOT100]每日一练------最长连续序列
算法·hot 100
csdn_aspnet29 分钟前
PHP 算法 LeetCode 编号 70 - 爬楼梯
算法·leetcode·php
沈浩(种子思维作者)1 小时前
没有错误,正确将一文不值
人工智能·python·算法·量子计算
x_xbx1 小时前
LeetCode:5. 最长回文子串
算法·leetcode·职场和发展
快手技术1 小时前
免费报名|生成式推荐技术如何实现体系化演进?快手技术沙龙第四期开启!
算法
初夏睡觉1 小时前
数字截断求和 题解
算法
AZaLEan__1 小时前
多源 BFS
java·开发语言·算法
smith成长之旅1 小时前
07 | Mem0 框架分析:三路信号融合——语义 + BM25 + Entity Boost 的混合检索
python·算法
wabs6661 小时前
关于贪心算法章节的【有两个维度问题】的自我总结
算法·贪心算法
未若君雅裁1 小时前
算法复杂度与数据结构:Java 集合篇的第一块基石
java·数据结构·算法