题目链接

BZOJ3243

题解

模数只有\(2\)或\(3\),可以大力讨论

如果模数为\(2\),乘积结果只有\(1\)或\(0\)

如果一个向量和前面所有向量乘积都为\(1\),那么其和前面向量前缀和的乘积就唯一确定

我们维护向量前缀和,第一个乘积情况不符的向量一定是答案,然后再枚举另一个向量即

\(O(nd)\)

如果模数为\(3\),乘积如果不为\(0\),还可以为\(1\)或\(2\),我们讨论的方法就不适用了

其实还是可以的

\[1^2 = 2^2 = 1 \pmod 3
\]

我们只要维护平方和即可

如何维护平方和?

\[(\sum\limits_{i = 1}^{d} a_ib_i)^2 = \sum\limits_{i = 1}^{d} \sum\limits_{j = 1}^{d} a_ia_jb_ib_j
\]

就相当于原来的\(d\)维向量变成了\(d^2\)维,\(O(nd^2)\)也是可以过的

#include<iostream>
#include<cstdio>
#include<cmath>
#include<ctime>
#include<cstring>
#include<algorithm>
#define LL long long int
#define Redge(u) for (int k = h[u],to; k; k = ed[k].nxt)
#define REP(i,n) for (int i = 1; i <= (n); i++)
#define BUG(s,n) for (int i = 1; i <= (n); i++) cout<<s[i]<<' '; puts("");
using namespace std;
const int maxn = 100005,maxm = 105,INF = 1000000000;
inline int read(){
int out = 0,flag = 1; char c = getchar();
while (c < 48 || c > 57){if (c == '-') flag = -1; c = getchar();}
while (c >= 48 && c <= 57){out = (out << 3) + (out << 1) + c - 48; c = getchar();}
return out * flag;
}
int n,d,P;
int a[maxn][maxm],id[maxn];
int sum[maxm],Sum[maxm][maxm];
int mult(int* a,int* b){
int re = 0;
for (int i = 1; i <= d; i++) re = (re + a[i] * b[i] % P) % P;
return re;
}
int Mult(int a[],int b[][maxm]){
int re = 0;
for (int i = 1; i <= d; i++)
for (int j = 1; j <= d; j++)
re = (re + a[i] * a[j] * b[i][j] % P) % P;
return re;
}
void solve1(){
for (int i = 1; i <= d; i++) sum[i] = a[id[1]][i];
for (int i = 2; i <= n; i++){
int t = mult(a[id[i]],sum);
if (t != ((i - 1) & 1)){
for (int k = 1; k < i; k++)
if (!mult(a[id[k]],a[id[i]])){
printf("%d %d\n",min(id[k],id[i]),max(id[i],id[k]));
break;
}
return;
}
for (int j = 1; j <= d; j++) sum[j] = (sum[j] + a[id[i]][j]) % P;
}
printf("-1 -1\n");
}
void solve2(){
for (int i = 1; i <= d; i++)
for (int j = 1; j <= d; j++)
Sum[i][j] = a[id[1]][i] * a[id[1]][j] % P;
for (int i = 2; i <= n; i++){
int t = Mult(a[id[i]],Sum);
if (t != (i - 1) % P){
for (int k = 1; k < i; k++)
if (!mult(a[id[k]],a[id[i]])){
printf("%d %d\n",min(id[k],id[i]),max(id[i],id[k]));
break;
}
return;
}
for (int j = 1; j <= d; j++)
for (int k = 1; k <= d; k++)
Sum[j][k] = (Sum[j][k] + a[id[i]][j] * a[id[i]][k] % P) % P;
}
printf("-1 -1\n");
}
int main(){
srand(time(NULL));
n = read(); d = read(); P = read();
for (int i = 1; i <= n; i++)
for (int j = 1; j <= d; j++)
a[i][j] = read() % P;
for (int i = 1; i <= n; i++) id[i] = i;
random_shuffle(id + 1,id + 1 + n);
if (P == 2) solve1();
else solve2();
return 0;
}

BZOJ3243 [Noi2013]向量内积 【乱搞】的更多相关文章

  1. BZOJ3243 NOI2013向量内积(随机化)

    考虑奇技淫巧. 首先是k=2.对向量维护一个前缀和,每次将当前向量与前缀和点乘.如果点乘结果不等于i-1&1,说明当前向量至少和之前的某个向量的数量积是2的倍数,暴力找就可以了.当然等于i-1 ...

  2. 【BZOJ-3243】向量内积 随机化 + 矩阵

    3243: [Noi2013]向量内积 Time Limit: 10 Sec  Memory Limit: 256 MBSec  Special JudgeSubmit: 1249  Solved:  ...

  3. 【fake题解】[NOI2013]向量内积

    [fake题解][NOI2013]向量内积 做法1 大暴力.哪里不会T哪里. 做法2 所有数都%=k不影响结果.(废话 k的取值只有2和3,所以肯定是要分类讨论的.k=2肯定简单些啦. k=2 出现的 ...

  4. [Noi2013]向量内积

    来自FallDream的博客,未经允许,请勿转载,谢谢. 两个d 维向量A=[a1,a2,...,ad]与B=[b1,b2,...,bd]的内积为其相对应维度的权值的乘积和,即: $\sum_{i=1 ...

  5. P1224 [NOI2013]向量内积

    传送门 发现这个内积和矩乘有点像,考虑构造一个 $n$ 行 $m$ 列的矩阵 $A$,每一行都是一个题目给定的 $m$ 维向量 设 $B=AA^T$ ,其中 $A^T$ 为 $A$ 的转置矩阵,那么对 ...

  6. luogu P1224 [NOI2013]向量内积

    传送门 挺有意思的一道题 暴力60就是枚举每个向量暴力check,随机选向量就能多骗一些分 然后两个向量内积要模\(k\)为\(0\),那么如果全部不为\(0\)就不合法.先考虑\(k=2\),对于向 ...

  7. BZOJ3243/UOJ121 [Noi2013]向量内积

    本文版权归ljh2000和博客园共有,欢迎转载,但须保留此声明,并给出原文链接,谢谢合作. 本文作者:ljh2000 作者博客:http://www.cnblogs.com/ljh2000-jump/ ...

  8. 3243: [Noi2013]向量内积 - BZOJ

    Description 两个d 维向量A=[a1,a2,...,ad]与B=[b1,b2,...,bd]的内积为其相对应维度的权值的乘积和,即: 现有 n 个d 维向量x1,...,xn ,小喵喵想知 ...

  9. 【uoj121】 NOI2013—向量内积

    http://uoj.ac/problem/121 (题目链接) 题意 给出${n}$个${d}$维向量,问是否有两个不同的向量的内积是${k}$的倍数. Solution 又卡了一上午常数,我弃了T ...

随机推荐

  1. ZooKeeper(1)-入门

    一. Zookeeper工作机制 二.Zookeeper特点 三.Zookeeper数据结构 四.Zookeeper应用场景 统一命名服务 统一配置管理 统一集群管理 服务器动态上下线 软负载均衡

  2. 9.1 IIC驱动源码分析

    学习目标:分析linux内核源码下的i2c总线驱动 drivers/i2c/busses/i2c-s3c2410.c 和 driver/i2c/chips/eeprom.c 设备驱动: 一.i2c驱动 ...

  3. ruby 可枚举模块Enumerable

    Enumerable模块提供了遍历,搜索,比较,排序等方法.如果我们自定义的类需要实现这些方法,必须实现一个each方法.如果需要使用max,min,sort等方法,因为这些方法是集合的元素之间的排序 ...

  4. Typora -- 书写即美学

    #Typora -- 书写即美学 ##基本快捷键--需要在所见即所想界面进行输入 加粗 Ctrl + B 加粗 斜体 Ctrl + I 斜体 下划线 Ctrl + U 下划线 删除线 Ctrl + S ...

  5. .NET CORE LOG

    .NET CORE LOG 合格的应用程序不仅要求运行的高效和计算的准确,稳定及可靠性也要得到满足,同事,系统的可维护性也相当重要.谈及到可维护性,就必须涉及到系统运行状态的监控和异常的快速定位与跟踪 ...

  6. 【Java】关于Spring框架的总结 (二)

    上文提到了 Spring 的 IoC 特性和 AOP 特性,只提到个别的实现方法.本文将对 IoC 和 AOP 其他方法进行讲解. 多种方式实现依赖注入 1.设值注入 上文中使用的注入方法:通过 se ...

  7. (转) Sqoop使用实例讲解

    原博客地址:http://blog.csdn.net/evankaka 摘要:本文主要讲了笔者在使用sqoop过程中的一些实例 一.概述与基本原理 Apache Sqoop(SQL-to-Hadoop ...

  8. java冒泡算法

    public static void maopao() { int temp; int[] values = {2, 34, 0, 245}; for (int i = 0; i < value ...

  9. .NET基础知识之七——索引器

           索引器是什么?有什么作用?索引器允许类的实例以访问数组的形式来访问对象里面的属性.如我们经常可以看到类似于dr["name"]="test",或者 ...

  10. ResolutionException: Cannot find candidate artifact for com.google.android.gms:play-services-ads-lite:[10.2.4]

    I had the same issue and I think it's solved now. Open AdMobDependencies.cs file, located inside of ...