D. Cross Coloring(逆向思维 + 点覆盖问题)
创始人
2025-05-28 01:44:27

Problem - D - Codeforces

有一张纸,可以用大小为n × m的网格表示:n行和m列的单元格。所有的细胞最初都是白色的。G操作已应用于该工作表。其中的i可以描述为:2i yi-从k种非白色中选择一种,然后给整行和整列y上色。新颜色应用于每个单元格,而不管该单元格在操作之前是否被着色。应用所有q运算后的薄片称为着色。如果至少有一个单元格被着色,则两种颜色是不同的有多少种不同的颜色?打印数字模998 244 353。输入第一行包含一个整数t (1

Example

input

Copy

 

2

1 1 3 2

1 1

1 1

2 2 2 3

2 1

1 1

2 2

output

Copy

3
4

注意:

如果使用#define int long long 是无法通过这道题的 会T

以后输入输出都用scanf,

题解

用于涂改是按顺序的,所以一个点是什么颜色都是由最后一次在这个点上染色决定的

所以我们反过来考虑

如果点没有被染色过,不考虑

记录点最后一次被染色,可以染k种,所以乘k

如何判断一个点被染过色

1.所有行被染过 都不考虑了

2.所有列被染过 都不考虑了

3.该行该列 被染过 不考虑了

用两个数组记录行列是否被染过即可

 

#include
#include
#include
#include
#include
#include
#include
#include
using namespace std;
//#define int long long
const int N = 4e6 + 10;
typedef pair PII;
int x[N],y[N];
PII p[N];
int mod =  998244353;
void solve() 
{int n,m,k,q;scanf("%d%d%d%d",&n,&m,&k,&q);int a = 0,b = 0;int ans = 1;for(int i = 1;i <= n;i++){x[i] = 0;}for(int j = 1;j <= m;j++){y[j] = 0;}for(int i = 1;i <= q;i++){scanf("%d%d",&p[i].first,&p[i].second);}for(int i = q;i >= 1;i--){if(a == n||b == m||(x[p[i].first]&&y[p[i].second])){continue;}if(!x[p[i].first]){x[p[i].first] = 1;a++;}if(!y[p[i].second]){y[p[i].second] = 1;b++;}ans = 1ll*ans*k%mod;}printf("%d\n",ans); 
}//1 2 4
signed main() 
{
//	ios::sync_with_stdio(0);
//	cin.tie(0);cout.tie(0);int t = 1;
//	cin >> t;
scanf("%d",&t);while (t--) {solve();}
}
//1 1 1 0 1//1 1 1 0 1
//1 1 1 0 1
//1 1 1 0 1
//0 1 1 1 1
//0 1 1 1 1

相关内容

热门资讯

大三竞选班长发言稿 大三竞选班... 大三竞选班长发言稿一  老师们,同学们:  大家好!  今天我站在这里,主要的目的就是竞选班长。  ...
最新或2023(历届)最新员工... 员工规章制度范本一  目的:规范公司办公室工作纪律,营造良好工作氛围,树立良好的企业形象。  第一条...
大一竞选班长发言稿3篇 大一竞...  大学生竞选班长发言稿一  尊敬的老师、亲爱的同学们:  大家好!  大学生活才刚开始一个多月,在前...
最新或2023(历届)《中华人... 《中华人民共和国无线电管理条例(修订草案)》  9月1日,国务院总理李克强主持召开国务院常务会议,会...
最新或2023(历届)关于医院... 护士是医疗卫生专业队伍的重要组成部分,以下是小编给大家整理提供的护士条例内容,快来阅读看看。  护 ...