P1224 [NOI2013] 向量内积

news/2025/1/19 15:14:27/文章来源:https://www.cnblogs.com/dcytrl/p/18679589

题意

给定 \(n\)\(d\) 维向量 \(a_i\),求一对合法的 \(i,j\) 使得 \(a_i\cdot a_j=0\),其中 \(\cdot\) 是向量点积,即 \(a_i\cdot a_j=\sum_{p=1}^d a_{i,p}a_{j,p}\)

\(n\le 10^5,d\le 30,2\le k\le 3\)

分析

考虑 \(k=2\) 怎么做。发现寻找一组解比较困难,考虑随机化。若无解,那么肯定满足 \(\forall i,j, a_i\cdot a_j\equiv 1\)。考虑随出一个集合 \(S\),并让集合 \(S\) 外的 \(i\)\(S\) 内的所有向量分别做点积并求和(模 \(k\) 意义下),若总和为 \(|S|\bmod k\),则这个 \(i\) 肯定与 \(S\) 内的某个点点乘后合法,暴力 check 即可。不难发现每次做一遍成功率至少为 \(\frac{1}{2}\),多做几次即可。复杂度 \(O(Knd)\)\(K\) 为随机次数。

考虑 \(k=3\)。这时无解,点积的结果可能为 \(1\)\(2\),相当的不好处理。但是注意到 \(1\)\(2\) 平方后的结果模 \(3\) 意义下均为 \(1\),把 \(\sum_{p=1}^d a_{i,p}a_{j,p}\) 转化为 \(\sum_{p=1}^d\sum_{q=1}^d a_{i,p}a_{i,q}a_{j,p}a_{j,q}\),这样就转化为了 \(d\leftarrow d^2\)\(k=2\),就好处理了。复杂度 \(O(Knd^2)\)

int n,m,d,k;
int a[maxn][maxm],b[maxms];
mt19937 rnd(time(0));
bool flag[maxn];
inline int get(int x,int y){return a[x][y/d]*a[x][y%d];
}
inline void solve_the_problem(){n=rd(),d=rd(),k=rd(),m=d*d;rep(i,1,n)rep(j,0,d-1)a[i][j]=rd()%k;rep(_,1,B){int tot=0;rep(i,1,n)flag[i]=rnd()%2,tot+=flag[i];rep(j,0,m-1)b[j]=0;rep(i,1,n)if(flag[i])rep(j,0,m-1)b[j]=(b[j]+get(i,j))%k;rep(i,1,n)if(!flag[i]){int sum=0;rep(j,0,m-1)sum=(sum+get(i,j)*b[j])%k;if(sum!=tot%k){rep(l,1,n)if(flag[l]){sum=0;rep(j,0,m-1)sum=(sum+get(i,j)*get(l,j))%k;if(!sum)return printf("%d %d",min(i,l),max(i,l)),void();}}}}printf("-1 -1");
}

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

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

远程桌面键盘记录器

针对远程桌面协议 (RDP) 相关进程的击键记录器,它利用键盘输入挂钩,允许其记录某些上下文中的击键(例如在 mstsc.exe 和 CredentialUIBroker.exe 中) 使用vs直接编译就可以了运行TakeMyRDP.exe打开mstsc,输入ip地址,输入账号密码密码直接显示出来,这个exe不需要高权限运行…

【nginx】Nginx重定向方法

Nginx重定向配置是一个功能强大且灵活的工具,可以根据具体需求实现各种重定向规则。 以下是对Nginx请求重定向配置方法的详细解析:1、基本概念 请求重定向是指当客户端向服务器发送一个请求时,服务器根据一定的规则将客户端的请求引导到另外一个URL的过程。在Nginx中,通过r…

利用mybatis拦截器记录sql,辅助我们建立索引(二)

背景 上一篇中讲述了mybatis的mapper初始化过程和执行过程,这篇再讲讲具体的拦截器的使用,以实现记录sql到持久化存储,通过分析这些sql,我们就能更方便地建立索引。 利用mybatis拦截器记录sql,辅助我们建立索引(一) 我本地项目的大概版本: spring boot版本2.7,mybatis版…

JMeter通过JSON提取器获取任意一行数据中的多个字段

存在如下响应信息: { "result": { "data": [ { "字段1": "DK-01", "字段2": null, "字段3": "210(3mm/40kg)",}, {&q…

Windows7 64位系统ODBC数据源配置方法

Windows7 64位系统ODBC数据源配置方法 注意以下所说的步骤是在安装好SQL2000或者端内有绿色SQL的情况下,已经在查询分析器内一键建立并还原好数据库之后才进行的,请不要跳步骤进行,否则会出错。一键端可直接操作。(win7系统架设传奇3前请将UAC账户权限调至最低) Windows7…

【clang-format】Windows11下代码格式化工具clang-format.exe下载

官方项目地址:https://github.com/llvm/llvm-project/releases下滑找到win64.exe下载慢的可以去这个github代下网站:https://d.serctl.com/下载好后不用安装,直接解压这个exe文件 把目录bin里面的clang-format.exe文件复制出来,放到一个新文件夹里,比如我放到了D盘根目录下…

聊一聊 操作系统蓝屏 c0000102 的故障分析

一:背景 1. 讲故事 今年以来不知道为啥总有些朋友加我微信,让我帮忙分析下操作系统蓝屏问题,我也觉得挺好奇的,就问了其中一位朋友,说是B站来的,我就在拼命回忆,为啥会找我分析蓝屏?突然想到了去年好像录了一集关于 CrowdStrike 的热点事件。。。我本来是做.NET程序的故…

4-01-(C++类 this指针)

结构体传参,传递的是副本 结构体里面写函数,结构体的大小不变 函数的地址不在结构体里面。 类里面的函数都要传一个this指针,即 lea ecx,[s] 普通的函数结构体传参 this指针的特点 1、你用或者不用,它就在那里 2、参数个数确定的时候,用ecx来传递 3、参数个数不确…

协议通道版iMessage蓝号检测,iMessages数据筛选,无痕检测是否开启iMessage服务

一、实现iMessage数据检测的两种方式:1.人工筛选,将要验证的号码输出到文件中,以逗号分隔。再将文件中的号码粘贴到iMessage客户端的地址栏,iMessage客户端会自动逐个检验该号码是否为iMessage账号,检验速度视网速而定。红色表示不是iMessage账号,蓝色表示iMessage账号。2…

【开源】一款功能全面的商用级溯源防伪系统,适用于各种溯源场景

项目介绍 HiPi是一款开源、功能全面的商用级溯源防伪系统,一物一码系统,适用于各种溯源场景的大、中、小、微规模企业。系统能够追踪记录产品的生命周期各个环节,并将产品信息保存在系统中,实现品牌保护、产品营销、防止假冒伪劣产品、防窜货、产品追踪溯源等功能。 应用场…

行为分析智能监测摄像机

行为分析智能监测摄像机具有高效的行为识别和分类能力。通过摄像头捕捉到目标区域内的行为活动,并通过预先训练好的机器学习算法进行识别和分类,可以准确地分析出不同的行为特征,例如跌倒、打架等,并及时发出警报或提醒相关管理人员。这种高效的行为识别能力可以帮助监控中…