当前位置: 首页 > article >正文

F - Simplified Reversi 矩阵侧边视角 修改

1 行修改的时候只🔥影响的是哪些位置 因为Queries are pairwise distinct.
也就是当前行修改过之后 当前行就不会重复修改。额。实际上如果没有这个条件也无所谓的 我们可以用一个vis来判重就行
2 用什么东西可以维护这样的区间修改
主要还是行列间的 查询和修改的互动。。还挺有意思

void solve() {
	cin >> n >> m;
	f.build(1, 1, n - 1, n - 1); //(root,l,r,val) //我们这边用n-1 。。到时候-1 。。这样会更舒服一点。
	g.build(1, 1, n - 1, n - 1);

	int ans = (n - 2) * (n - 2);

	while (m--) {
		int o, i;
		cin >> o >> i;
		if (o == 1) {
			int t = g.query(1, i, i);// (root,l,r)我们要找到当前列。他能到的底部位置
			ans -= t - 1;
			f.update(1, 1, t, i - 1);//(root,l,r,val)列的底部位置 就是行 [1,t]需要更新能到的最远距离i
		} else {
			int t = f.query(1, i, i);//(root,l,r)上下相反就行了。。
			ans -= t - 1;
			g.update(1, 1, t, i - 1);
		}
	}

	cout << ans << '\n';
};

这代码省略了。。线段树主模版。。对线段树熟悉的。一般能看的懂。


http://www.kler.cn/a/291520.html

相关文章:

  • MongoDB聚合操作
  • 自动化生成测试用例:利用OpenAI提升电商网站测试覆盖率
  • 网络爬虫 Python 第二课
  • 编程语言02:语法基础
  • 自动化运维-检测Linux服务器CPU、内存、负载、IO读写、机房带宽和服务器类型等信息脚本
  • 数据库基本概念学习笔记
  • Python Invoke:强大的自动化任务库
  • C++ 重载运算符和重载函数
  • 构建全景式智慧文旅生态:EasyCVR视频汇聚平台与AR/VR技术的深度融合实践
  • Spark MLlib模型训练—回归算法 Linear regression
  • 不限专业和工作经验,这个含金量巨高的IT证书,90%的大学生都不知道!
  • FPGA 编程基础, 赋值操作符, 运算符使用, 条件表达式, 信号操作方法
  • 工业应用软件开发实训室(边缘计算)建设方案
  • sportbugs报告路径在linux和windows中的配置差异
  • Linux 文件操作相关函数整理
  • 基于django的在线音乐网站设计/基于python的音乐播放系统
  • Node.js模块系统
  • C#转java工具
  • 鸿蒙轻内核M核源码分析系列二一 02 文件系统LittleFS
  • 【C++设计模式】(三)创建型模式:单例模式
  • 前端框架对比
  • 学习netty 从哪里开始
  • 【Java毕业设计】基于SpringBoot+Vue+uniapp的农产品商城系统
  • 【PyTorch常用库函数】torch.add():张量的加法操作
  • 算法训练营——day4螺旋矩阵
  • 数据结构---双向链表---循环链表---栈