AtCoder Beginner Contest 334 G

2023-12-29 21:44
文章标签 atcoder beginner contest 334

本文主要是介绍AtCoder Beginner Contest 334 G,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

G.Christmas Color Grid 2(枚举,Tarjan)

题意:

本题与问题 E E E类似。有一个 H H H行和 W W W列的网格,每个单元格都被涂成红色或绿色。用 ( i , j ) (i,j) (i,j)表示从上到下第 i i i行、从左到右第 j j j列的单元格。 ( i , j ) (i,j) (i,j)单元格的颜色由字符 S i , j S_{i,j} Si,j表示,其 S i , j = S_{i,j}= Si,j=".“表示 ( i , j ) (i,j) (i,j)单元格是红色,而 S i , j = S_{i,j}= Si,j=”#"表示 ( i , j ) (i,j) (i,j)单元格是绿色。

定义绿色连通分量是指顶点集是绿色单元格、边缘集为连接两个相邻绿色单元格的单元格的集合。当 ∣ x − x ′ ∣ + ∣ y − y ′ ∣ = 1 \lvert x−x^′\rvert + \lvert y−y^′\rvert=1 xx+yy=1时,单元格 ( x , y ) (x,y) (x,y) ( x ′ , y ′ ) (x',y') (x,y)被认为是相邻的。

选择一个绿色单元格并随机地将其重新涂成红色。计算重新涂色后网格中绿色连通分量数量的期望值,结果对 998244353 998244353 998244353取模。

分析:

对于本题,枚举要修改的点,可以把相邻的绿色互相连边,这样操作之后原题就成了一个无向图上删掉一个点剩下的连通块个数。

可以使用 T a r j a n Tarjan Tarjan算法,设 u u u为当前结点, v v v为子节点,若跑完 v v v后,得到 d f n n ≤ l o w v dfn_n \le low_v dfnnlowv,则说明从 u u u的父亲结点,经过 u u u才能够到达 v v v,如果把结点 u u u删掉,则不能到达结点 v v v了。

这就相当于删去结点 u u u时, u u u的父亲结点与结点 v v v会被分成两个连通块,即这两部分无法相互到达,因此只需要数一下对于结点 u u u,它有多少个 v v v,满足 d f n n ≤ l o w v dfn_n \le low_v dfnnlowv,当然其实 u u u的父亲结点也算是一个儿子节点,因此需要加一表示算上父亲节点。但每次 T a r j a n Tarjan Tarjan的起点是没有父亲节点的,所以不需要加一。

综上,删去一个结点 u u u会造成的影响为:假设删去结点u会增加 a u a_u au个连通块,这个无向图初始包含 m m m个连通块,这个节点原来是属于1个连通块的,它删去后会增加 a u a_u au个连通块,那么删去这个结点后连通块的数量应为 m + a u + 1 m+a_u+1 m+au+1

代码:

#include<bits/stdc++.h>using namespace std;
typedef long long LL;
const LL MOD = 998244353;
char mp[1005][1005];
LL n, m;LL head[1000005], nxt[10000005], to[10000005], ecnt;void add(LL u, LL v) {to[++ecnt] = v;nxt[ecnt] = head[u];head[u] = ecnt;
}void adde(LL x, LL y) {add(x, y);add(y, x);
}LL f(LL x, LL y) {return (x - 1) * m + y;
}LL dfn[1000005], low[1000005], deg[2000005];
LL ncnt;
LL stk[1000005], sz;void tarjan(LL x) {stk[++sz] = x;dfn[x] = low[x] = ++ncnt;for (LL i = head[x]; i; i = nxt[i]) {LL v = to[i];if (!dfn[v]) {tarjan(v);low[x] = min(low[x], low[v]);if (low[v] == dfn[x]) {LL t;do {t = stk[sz--];deg[t]++;} while (t != x);stk[++sz] = x;}} elselow[x] = min(low[x], dfn[v]);}
}LL qpow(LL x, LL y) {LL ret = 1;while (y) {if (y & 1)ret = ret * x % MOD;x = x * x % MOD;y >>= 1;}return ret;
}int main() {for (LL i = 1; i <= n; i++) {string str;cin >> str;for (LL j = 1; j <= m; j++) {mp[i][j] = str[j - 1];if (mp[i][j] == '#') {if (mp[i - 1][j] == mp[i][j])adde(f(i - 1, j), f(i, j));if (mp[i][j - 1] == mp[i][j])adde(f(i, j - 1), f(i, j));}}}LL xcnt = 0, cnt = 0, tot = 0;for (LL i = 1; i <= n; i++) {for (LL j = 1; j <= m; j++) {cnt += (mp[i][j] == '#');if (mp[i][j] == '#' && !dfn[f(i, j)])tarjan(f(i, j)), ++xcnt;}}for (LL i = 1; i <= n; i++) {for (LL j = 1; j <= m; j++) {if (mp[i][j] == '#') {tot += xcnt - 1 + deg[f(i, j)];tot >= MOD ? (tot -= MOD) : 0;}}}cout << tot * qpow(cnt, MOD - 2) % MOD;return 0;
}

学习交流


以下为学习交流QQ群,群号: 546235402,每周题解完成后都会转发到群中,大家可以加群一起交流做题思路,分享做题技巧,欢迎大家的加入。

这篇关于AtCoder Beginner Contest 334 G的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/550815

相关文章

2014 Multi-University Training Contest 8小记

1002 计算几何 最大的速度才可能拥有无限的面积。 最大的速度的点 求凸包, 凸包上的点( 注意不是端点 ) 才拥有无限的面积 注意 :  凸包上如果有重点则不满足。 另外最大的速度为0也不行的。 int cmp(double x){if(fabs(x) < 1e-8) return 0 ;if(x > 0) return 1 ;return -1 ;}struct poin

2014 Multi-University Training Contest 7小记

1003   数学 , 先暴力再解方程。 在b进制下是个2 , 3 位数的 大概是10000进制以上 。这部分解方程 2-10000 直接暴力 typedef long long LL ;LL n ;int ok(int b){LL m = n ;int c ;while(m){c = m % b ;if(c == 3 || c == 4 || c == 5 ||

2014 Multi-University Training Contest 6小记

1003  贪心 对于111...10....000 这样的序列,  a 为1的个数,b为0的个数,易得当 x= a / (a + b) 时 f最小。 讲串分成若干段  1..10..0   ,  1..10..0 ,  要满足x非递减 。  对于 xi > xi+1  这样的合并 即可。 const int maxn = 100008 ;struct Node{int

AtCoder Beginner Contest 370 Solution

A void solve() {int a, b;qr(a, b);if(a + b != 1) cout << "Invalid\n";else Yes(a);} B 模拟 void solve() {qr(n);int x = 1;FOR(i, n) FOR(j, i) qr(a[i][j]);FOR(i, n) x = x >= i ? a[x][i]: a[i][x];pr2(

CF Bayan 2015 Contest Warm Up B.(dfs+暴力)

B. Strongly Connected City time limit per test 2 seconds memory limit per test 256 megabytes input standard input output standard output 题目链接: http://codeforces.com/contest/475/probl

CF Bayan 2015 Contest Warm Up A.(模拟+预处理)

A. Bayan Bus time limit per test 2 seconds memory limit per test 256 megabytes input standard input output standard output 题目链接: http://codeforces.com/contest/475/problem/A The fi

AtCoder Beginner Contest 369 D - Bonus EXP 动态规划

原题链接: https://atcoder.jp/contests/abc369/tasks/abc369_d 思路:   这道题为什么要用动态规划呢,其实,对于第i个怪物,我们有打与不打两种处理方式,而对于打,我们是获得两倍的经验值,还是一倍的经验值,与我们打了奇数只怪物还是打了偶数只怪物有关了,因此我们定义dp[i][0] 为前i只怪物总共打了偶数次,dp[i][1] 为前i只怪物总

2015 Multi-University Training Contest 5 1009 MZL#39;s Border

MZL's Border  Problem's Link:  http://acm.hdu.edu.cn/showproblem.php?pid=5351   Mean:  给出一个类似斐波那契数列的字符串序列,要你求给出的f[n]字符串中截取前m位的字符串s中s[1...i] = s[s.size()-i+1....s.size()]的最大长度。 analyse:   过计算

【UVa】10600 ACM Contest and Blackout 次小生成树

类型:次小生成树 题目大意: 为了举办ACM竞赛,市长决定给所有的n(3 <= n <= 100)所学校提供可靠的电力供应。当且仅当一个学校直接连到电站,或者连到另一个有可靠供应的学校时,才有可靠供应。现在给出在不同学校之间的布线成本,找出最便宜的两种连线方案。一个方案的成本等于其中所有学校之间连线的成本的总和。 题目分析: 次小生成树。 先求出最小生成树,然后枚举所有不在

【POJ】3660 Cow Contest floyd(可以拓扑排序?)

Cow Contest Time Limit: 1000MS Memory Limit: 65536KTotal Submissions: 6925 Accepted: 3792 Description N (1 ≤ N ≤ 100) cows, conveniently numbered 1..N, are participating i