G. Best ACMer Solves the Hardest Problem

news2025/2/25 21:24:41

Problem - G - Codeforces

有一天,一位优秀的ACMer将离开这个领域,面对新的挑战,就像前辈们所做的一样。他们中的一些人接管了家族企业,一些人在失业的边缘挣扎。一些人有勇气展示自己,成为专业的Ingress玩家,一些人仍在不断挑战自己的极限,尝试解决Project Euler中的所有问题。

但是,对于前国王Benecol de Cecco来说,所有这些目的都太肤浅了。他现在所做的就是成为StackOverflow上最好的回答者。StackOverflow是最大、最值得信赖的在线社区,供开发人员学习、分享他们的编程知识和建立他们的职业生涯。

今天,他注意到了一个问题,由Kevin Li发布,说:最近,我实现了一个实验,需要找到所有数据记录,它们到查询点q的欧几里得距离是相同的值r。我尝试使用k-d树来提高搜索效率。然而,我发现k-d树需要遍历所有叶节点才能返回结果,也就是说,它仍然需要比较所有数据集才能获得结果。

这个问题可以形式化地建立一个具有实时查询和修改的数据库。首先,假设我们在平面上有n个不同的点。第i个点位于(xi,yi)处,具有权重wi。然后,我们考虑动态给出的几个查询和修改:

1 x y w,插入一个权重为w的新点(x,y),在操作之前我们保证没有点位于那个位置; 2 x y,删除位于(x,y)处的点,在操作之前我们保证该点存在; 3 x y k w,对于每个到(x,y)的欧几里得距离为k−−√的点,将其权重增加w; 4 x y k,查询所有到(x,y)的欧几里得距离为k−−√的点的权重总和。

Benecol de Cecco说这个问题很容易,他让我与大家分享这个问题。顺便说一下,两个点(x0,y0)和(x1,y1)之间的欧几里得距离等于(x0−x1)2+(y0−y1)2−−−−−−−−−−−−−−−−−−√。

输入 输入包含多个测试用例,第一行包含一个正整数T,表示测试用例的数量,最多为1000。

对于每个测试用例,第一行包含两个整数n和m,表示平面上的初始点数和操作数,其中1≤n,m≤105。

以下每个n行都包含三个整数x、y和w,满足1≤x,y,w≤6000,描述了初始时位于(x,y)处的权重为w的点。

以下每个m行都包含一个查询或修改操作。这些操作采用上述形式给出。为使所有操作中的x和y动态化,我们使用lastans表示最近查询的答案,其初始值为零。对于输入中具有值x和y的每个操作,它们的实际值应为(((x+lastans)mod6000)+1)和(((y+lastans)mod6000)+1)。操作中的所有系数都是整数,满足0≤k≤107和1≤x,y,w≤6000。

我们保证所有测试用例中n和m的总和分别不超过106。

输出 对于每个测试用例,首先输出一行包含“Case #x:”(不带引号),其中x是从1开始的测试用例编号。

然后对于每个查询,在一行中输出一个整数表示答案。

Example

Input

Copy

1
3 6
2999 3000 1
3001 3000 1
3000 2999 1
1 2999 3000 1
4 2999 2999 1
2 2995 2996
3 2995 2995 1 1
4 2995 2995 1
4 3000 3000 1

Output

Copy

Case #1:
4
6
0

Note

In the sample case, if we ignore the special input format for dynamic x

and y

in operations, here we can show these modifications and queries directly in an offline format as follows:

  • 1 3000 3001 1;
  • 4 3000 3000 1;
  • 2 3000 3001;
  • 3 3000 3000 1 1;
  • 4 3000 3000 1;
  • 4 3007 3007 1.

题解:
假设点tx,ty与此时的点x,y的距离为根号k

(tx - x)^2 + (ty - y)^2 = k

设dx = tx - x

dy = ty - y

由于k的大小只有1e7,x,y的大小最多6000

我们可以枚举出来,所有满足k的dx和dy

那么符合条件的

tx = x - dx

ty = y - dy

又因为我们求的dx,dy都是正的,但是他们可能是负的,所以有四种情况

具体细节见代码,

比赛中由re导致的错误情况有很多,大小超int也可能导致

#include<bits/stdc++.h>
using namespace std;
//#define int long long
const int N=1e7 + 10;
typedef pair<int,int> PII;
vector<PII> p[N];
bool vis[7010][7010];
int res[7010][7010];
int dx[4] = {1,1,-1,-1};
int dy[4] = {1,-1,1,-1};
int idx;
void solve()
{
	long long last = 0;
	int n,q;
	cin >> n >> q;
	vector<PII> t; 
	for(int i = 1;i <= n;i++)
	{
		int x,y,w;
		cin >> x >> y >> w;
		t.push_back({x,y});
		vis[x][y] = 1;
		res[x][y] = w;
	}
	cout <<"Case #"<<++idx<<":\n";
	while(q--)
	{
		int op,x,y,k,w;
		cin >> op >> x >> y;
		x = (x + last)%6000 + 1;
		y = (y + last)%6000 + 1;
		t.push_back({x,y});
		
		
		if(op == 1)
		{
			cin >> w;
			vis[x][y] = 1;
			res[x][y] = w;
		}
		else if(op == 2)
		{
			vis[x][y] = 0;
			res[x][y] = 0;
		}
		else if(op == 3)
		{
			cin >> k >> w;
			if(!p[k].size())
			continue;
			set<PII> s;
			for(auto [nx,ny]:p[k])
			{
				for(int j = 0;j < 4;j++)
				{
					int tx = x + dx[j]*nx;
					int ty = y + dy[j]*ny;
					if(tx <= 0||tx > 6000||ty <= 0||ty > 6000)
					continue;
					s.insert({tx,ty});
				}
			}	
			
			
			for(auto[tx,ty]:s)
			{
				if(vis[tx][ty])
				res[tx][ty] += w;
			}
			
			
		}
		else
		{
			cin >> k;
			last = 0;
			if(!p[k].size())
			{
				cout <<last <<"\n";
				continue;
			}
			set<PII> s;
			for(auto [nx,ny]:p[k])
			{
				for(int j = 0;j < 4;j++)
				{
					int tx = x + dx[j]*nx;
					int ty = y + dy[j]*ny;
					if(tx <= 0||tx > 6000||ty <= 0||ty > 6000)
					continue;
					s.insert({tx,ty});
				}
			}			
			
			for(auto[tx,ty]:s)
			{
				if(vis[tx][ty])
				last += res[tx][ty];
			}
			cout << last <<"\n";
		}
	}
	
	for(auto tt:t)
	{
		vis[tt.first][tt.second] = 0;
		res[tt.first][tt.second] = 0;
	}
	t.clear();
}
int main()
{
//	ios::sync_with_stdio(0);
//	cin.tie(0);
//	cout.tie(0);
	for(int i = 0;i <= 6000;i++)
	{
		for(int j = 0;j <= 6000;j++)
		{
			if(i*i + j*j > 1e7)
			{
				break;
			}
			p[i*i + j*j].push_back({i,j});
		}
	}
	int t = 1;
	cin >> t;
	while(t--)
	{
		solve();
	}
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1027528.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

YMatrix 5 社区版本安装介绍

本文描述YMatrix 5.1版本的安装过程&#xff0c;由于使用的操作系统为CentOS 7&#xff0c;具体步骤参考官网https://www.ymatrix.cn/doc/5.0/install/mx5_cluster/mx5_cluster_centos7 一. 安装准备 1 下载YMatrix社区版安装包 下载地址&#xff1a;https://www.ymatrix.cn…

视频播放器的技术组成

Qt视频播放器实现(目录) 什么是视频 我们这里讲的视频,通常也包括了音频。因为没有声音的画面播放几乎是不可接受的。 这样暗含了一个事实,那就是视频总是包括视频数据和音频数据两部分。 Video 表示视频; Audio 表示音频; 视频播放器播放什么 如同本专栏介绍描述…

python+nodejs+php+springboot+vue 基于数据元标准的教材征订管理系统

教材征订管理系统主要实现角色有管理员和用户,管理员在后台管理学院模块、学生模块、用户表模块、token表模块、教材选定模块、教材入库模块、教材分配模块、教材订购模块、教材模块、配置文件模块、出版社模块。 拟开发的教材征订管理系统通过测试,确保在最大负载的情况下稳定…

比特币 ZK 赏金系列:第 1 部分——支付解密密钥

以前&#xff0c;我们使用零知识赏金 (ZKB) 来支付比特币上的数独解决方案。在本系列中&#xff0c;我们将使用 ZKB 来解决范围更广的更实际的问题。 在第 1 部分中&#xff0c;我们应用 ZKB 来支付解密密钥。假设 Alice 使用对称密钥 K 加密她的文件。为了安全起见&#xff0…

行为树的基本概念和C++库

一 说明 行为树是计算机科学、机器人技术、控制系统和视频游戏中使用的计划执行的数学模型。它们以模块化方式描述一组有限任务之间的切换。他们的优势来自于他们能够创建由简单任务组成的非常复杂的任务&#xff0c;而不用担心简单任务是如何实现的。行为树与分层状​​态机有…

nuxt使用echarts

直接在页面写 bug1&#xff1a;安装包报错&#xff0c;就更换版本 bug2&#xff1a;图表出不来&#xff1a;需要定义宽高 bug3&#xff1a;需要resize大小 安装 npm install echarts4.9.0 plugins文件夹下新建echarts.js import Vue from vue import echarts from echarts /…

Windows 下 MySQL 8.1 图形化界面安装、配置详解

首先我们下载安装包 官方下载链接&#xff1a; MySQL :: Begin Your Download 网盘链接: https://pan.baidu.com/s/1FOew6-93XpknB-bYDhDYPw 提取码: brys 外网下载慢的同学可以使用上述网盘链接 下载完成后我们双击安装包即可进入安装界面 点击next 勾选同意协议&#…

【AIGC】图片生成的原理与应用

前言 近两年 AI 发展非常迅速&#xff0c;其中的 AI 绘画也越来越火爆&#xff0c;AI 绘画在很多应用领域有巨大的潜力&#xff0c;AI 甚至能模仿各种著名艺术家的风格进行绘画。 目前比较有名商业化的 AI 绘画软件有 Midjourney、DALLE2、以及百度出品的文心一格&#xff1a;…

解锁前端Vue3宝藏级资料 第五章 Vue 组件应用 4 ( provide 和 inject )

5.5 provide 和 inject 前面的知识告诉我们vue中组件之间传递值需要使用props来完成&#xff0c;但是props也有一定局限性。这个时候在vue3中还有另外的解决方法。那就是使用 provide 和 inject 允许父组件将数据传递给所有后代组件&#xff0c;而不管组件层次结构有多深。你要…

【linux基础(八)】计算机体系结构--冯诺依曼系统操作系统的再理解

&#x1f493;博主CSDN主页:杭电码农-NEO&#x1f493;   ⏩专栏分类:Linux从入门到精通⏪   &#x1f69a;代码仓库:NEO的学习日记&#x1f69a;   &#x1f339;关注我&#x1faf5;带你学更多操作系统知识   &#x1f51d;&#x1f51d; 计算机体系结构 1. 前言2. 冯…

eBPF深度探索: 高效DNS监控实现

eBPF可以灵活扩展Linux内核机制&#xff0c;本文通过实现一个DNS监控工具为例&#xff0c;介绍了怎样开发实际的eBPF应用。原文: A Deep Dive into eBPF: Writing an Efficient DNS Monitoring eBPF[1]是内核内置的虚拟机&#xff0c;在Linux内核内部提供了高层库、指令集以及执…

Javascript小案例--树形菜单(菜单数据为对象)

理论上菜单层级可以无限多&#xff0c;因为是递归渲染。 gif效果图&#xff1a; 代码 <!DOCTYPE html> <html lang"en"><head><meta charset"UTF-8"><meta name"viewport" content"widthdevice-width, initi…

RHCE---Linux的计划任务

文章目录 前言一、pandas是什么&#xff1f;二、使用步骤 1.引入库2.读入数据总结 前言 如果想要让自己设计的备份程序可以自动地在系统下面运行&#xff0c;而不需要手动来启动它&#xff0c;这是该如何处理&#xff1f;这些任务可以分为【单一】任务和【循环】任务&#xff0…

集简云票税通,高效、管理销项发票,满足多样化开票需求

随着数字化时代的到来&#xff0c;传统的纸质发票已经逐渐被电子发票所替代。然而&#xff0c;对于许多企业来说&#xff0c;管理和开具大量的销项发票仍然是一项繁琐的任务&#xff1a; 票税处理成本高&#xff0c;手工开票效率低。部分企业手工开票量大&#xff0c;耗费大量财…

问题:conda删除虚拟环境,报错no package names supplied

用conda 用 conda remove -n ScratchDet_20200114 删除虚拟 环境ScratchDet_20200114时报错 conda remove -n ScratchDet_20200114CondaValueError: no package names supplied,try "conda remove -h" for more details 解决方法&#xff0c;用下面的命令 conda env…

C++——vector(3)

作者&#xff1a;几冬雪来 时间&#xff1a;2023年9月20日 内容&#xff1a;C部分——vector内容讲解 目录 前言&#xff1a; erase&#xff1a; erase和insert总结&#xff1a; resize&#xff1a; 深拷贝&#xff1a; 赋值&#xff1a; 结尾&#xff1a; 前言&…

CentOS7在磁盘 Disk /dev/vdb 格式化为xfs, 创建逻辑卷saas,并挂载到/home/saas

CentOS7在磁盘 Disk /dev/vdb 格式化为xfs&#xff0c; 创建逻辑卷saas&#xff0c;并挂载到/home/saas CentOS7在磁盘 Disk /dev/vdb 格式化为xfs&#xff0c; 创建逻辑卷saas&#xff0c;并挂载到/home/saasCentOS7在磁盘 Disk /dev/vdb 格式化为xfs&#xff0c;并挂载到/ho…

关于安卓SVGA浅尝(一)svgaplayer库的使用

关于安卓SVGA浅尝&#xff08;一&#xff09;使用 相关链接 SVGA官网 SVGA-github说明文档 背景 项目开发&#xff0c;都会和动画打交道&#xff0c;动画的方案选取&#xff0c;就有很多选择。如Json动画&#xff0c;svga动画&#xff0c;gif等等。各有各的优势。目前项目中…

什么是浏览器的同源策略(same-origin policy)?它对AJAX有什么影响?

聚沙成塔每天进步一点点 ⭐ 专栏简介⭐ 浏览器的同源策略&#xff08;Same-Origin Policy&#xff09;⭐ 同源策略对AJAX的影响⭐ 写在最后 ⭐ 专栏简介 前端入门之旅&#xff1a;探索Web开发的奇妙世界 欢迎来到前端入门之旅&#xff01;感兴趣的可以订阅本专栏哦&#xff01;…

Mybatis 映射器中使用@InsertProvider,@UpdateProvider,@DeleteProvider,@SelectProvider

上一篇我们介绍了在Mybatis映射器的映射方法中使用Param接收多个参数&#xff1b;本篇我们继续介绍如何在Mybatis的映射器中使用动态SQL。 如果您对Mybatis映射器的映射方法中使用Param接收多个参数不太了解&#xff0c;建议您先进行了解后再阅读本篇&#xff0c;可以参考&…