F - Rook on Grid 矩阵 侧面视角 树状数组

两种走法

先下再右 吃到的就是L[i]-1个

先右再下 就吃剩的哈哈 每个L[i]挡住的阴影部分 才是有效的吃到部分

关于阴影 🔥可以想象从矩阵右侧有光线照进来。然后被障碍物挡住的那些空格。

处理方式可以按照列扫过去。一边用树状数组维护那些有阴影的行

实现的主要部分就是怎么去维护那些阴影。

小tip:>=r[i]都当做第一列开始就有阴影
题目

cpp 复制代码
#include <bits/stdc++.h>
using namespace std;
#define int long long
#define ll __int128_t
#define ar array<int, 2>
#define arr array<int, 3>
int  n, m, k, inf = 1LL << 61, mod = 998244353;// 1e9+7;
const int N = 5e5 + 50;
int tr[N + 1];
void add(int x, int v) {
	while (x <= N) {//这个N-1变量是开放的。。是个隐患。。
		tr[x] += v, x += x & (-x);
	}
}
int query(int x) {
	int s = 0;
	while (x) {
		s += tr[x], x -= x & (-x);
	}
	return s;
}
void solve() {
	cin >> n >> m >> k;
	vector<int>l(n + 1, m + 1), r(m + 1, n + 1);//这边我们统计非法的第一个位置
	for (int i = 1; i <= k; ++i) {
		int x, y;
		cin >> x >> y;
		l[x] = min(l[x], y);
		r[y] = min(r[y], x);
	}

	int ans = 0;
	vector<int>mp[m + 2];// 他有可能是m+1 。所以这里要开大点
	//计算 先下再右
	for (int i = 1; i < r[1]; ++i) { 
		ans += l[i] - 1;
		mp[l[i]].push_back(i);
	}

	for (int i = r[1]; i <= n; ++i)//>=r[i]都当做第一列开始就有阴影
		mp[1].push_back(i);

    //先右再下
	for (int i = 1; i < l[1]; ++i) {
		ans += query(r[i] - 1);
		for (int j : mp[i])
			add(j, 1);
	}

	cout << ans;
};


// 这题看似简单。。但是实际上是一类题目的典型处理方式。。

signed main() {
	ios::sync_with_stdio(false);
	cin.tie(0);
	cout << fixed << setprecision(15);
#ifdef DEBUG
	freopen("../1.in", "r", stdin);
#endif
	//init_f();
	//init();
	//expr();
	// int T; cin >> T; while(T--)
	solve();
	return 0;
}
相关推荐
草履虫建模5 小时前
力扣算法 1768. 交替合并字符串
java·开发语言·算法·leetcode·职场和发展·idea·基础
naruto_lnq7 小时前
分布式系统安全通信
开发语言·c++·算法
Jasmine_llq8 小时前
《P3157 [CQOI2011] 动态逆序对》
算法·cdq 分治·动态问题静态化+双向偏序统计·树状数组(高效统计元素大小关系·排序算法(预处理偏序和时间戳)·前缀和(合并单个贡献为总逆序对·动态问题静态化
爱吃rabbit的mq8 小时前
第09章:随机森林:集成学习的威力
算法·随机森林·集成学习
(❁´◡`❁)Jimmy(❁´◡`❁)9 小时前
Exgcd 学习笔记
笔记·学习·算法
YYuCChi9 小时前
代码随想录算法训练营第三十七天 | 52.携带研究材料(卡码网)、518.零钱兑换||、377.组合总和IV、57.爬楼梯(卡码网)
算法·动态规划
不能隔夜的咖喱10 小时前
牛客网刷题(2)
java·开发语言·算法
VT.馒头10 小时前
【力扣】2721. 并行执行异步函数
前端·javascript·算法·leetcode·typescript
进击的小头10 小时前
实战案例:51单片机低功耗场景下的简易滤波实现
c语言·单片机·算法·51单片机
咖丨喱12 小时前
IP校验和算法解析与实现
网络·tcp/ip·算法