【setDS】牛客小白月赛83 E

登录---专业IT笔试面试备考平台_牛客网

题意

思路

首先,一个必要步骤是把它转化为两个序列,这样就变成了一个序列DS问题

我们的答案是一个位置 pos 后面还有多少位置和这个位置的颜色相同,考虑得到这个答案我们需要维护什么东西

我们只需要维护颜色之间的边界的位置即可

用 set 维护位置,剩下就是常规的增删改查了

cpp 复制代码
#include <bits/stdc++.h>

#define int long long

constexpr int N = 5e2 + 10;
constexpr int M = 1e4 + 10;
constexpr int mod = 998244353;
constexpr int Inf = 0x3f3f3f3f;

std::set<int> sa, sb;

int n, m;

int a(int i, int j) {
	if (i & 1) {
		return (i - 1) * m + j;
	}else {
		return i * m - (j - 1);
	}
}
int b(int i, int j) {
	if (j & 1) {
		return (j - 1) * n + i;
	}else {
		return j * n - (i - 1);
	}
}
void upd(std::set<int> &S, std::vector<char> &V, int i, char x) {
	S.erase(i);
	S.erase(i + 1);
	V[i] = x;
	if (V[i] != V[i - 1]) {
		S.insert(i);
	}
	if (V[i] != V[i + 1]) {
		S.insert(i + 1);
	}
}
void solve() {
	std::cin >> n >> m;
	std::vector<char> va(n * m + 2), vb(n * m + 2);
	for (int i = 1; i <= n; i ++) {
		for (int j = 1; j <= m; j ++) {
			char x;
			std::cin >> x;
			upd(sa, va, a(i, j), x);
			upd(sb, vb, b(i, j), x);
		}
	}
	int q;
	std::cin >> q;
	while(q --) {
		int op, x, y;
		char c;
		std::cin >> op;
		if (op == 1) {
			std::cin >> x >> y >> c;
			upd(sa, va, a(x, y), c);
			upd(sb, vb, b(x, y), c);
		}else if (op == 2) {
			std::cin >> x >> y;
			std::cout << (*sa.upper_bound(a(x, y))) - a(x, y) << "\n";
		}else {
			std::cin >> x >> y;
			std::cout << (*sb.upper_bound(b(x, y))) - b(x, y) << "\n";
		}
	}
}
signed main(){
    std::ios::sync_with_stdio(false);
    std::cin.tie(nullptr);

    int t = 1;
    while(t --) {
        solve();
    }
    return 0;
}
相关推荐
Trouvaille ~2 小时前
【C++篇】在秩序与混沌的交响乐中: STL之map容器的哲学探寻
开发语言·数据结构·c++·算法·迭代器模式·stl·map
nuyoah♂3 小时前
DAY18|二叉树Part06|LeetCode: 530.二叉搜索树的最小绝对差、501. 二叉搜索树中的众数、236.二叉树的最近公共祖先
算法·leetcode
五条凪4 小时前
从零开始的LeetCode刷题日记:70. 爬楼梯
数据结构·算法·leetcode·职场和发展·1024程序员节
小丁爱养花5 小时前
算法专题:栈
数据结构·算法·leetcode
azhou的代码园5 小时前
基于SpringBoot+微信小程序+协同过滤算法+二维码订单位置跟踪的农产品销售平台-新
spring boot·算法·微信小程序
cuisidong19975 小时前
5G无线帧基本架构
网络·算法·5g
地平线开发者5 小时前
【征程 6 工具链性能分析与优化-1】编译器预估 perf 解读与性能分析
算法·自动驾驶
兔兔爱学习兔兔爱学习6 小时前
leetcode206. Reverse Linked List
算法
Ws_6 小时前
leetcode-有效的字母异位词
python·算法·leetcode
玛卡巴卡(努力学习版)6 小时前
每日算法练习
算法