题目链接


\(Description\)

给定\(n\)个十维向量\(\overrightarrow{V_i}=x_1,x_2,...,x_{10}\)。定义\(\overrightarrow{V}=x_1,x_2,...,x_{10}\)的模长\(|\overrightarrow{V}|=\sqrt{x_1^2+x_2^2+...+x_{10}^2}\)。求有多少个四元组\(1\leq i,j,k,l\leq n\)满足\(|\overrightarrow{V_i}-\overrightarrow{V_j}|=|\overrightarrow{V_k}-\overrightarrow{V_l}|\)。

\(n\leq10^5,\ 0\leq x_i\leq2\)。

\(Solution\)

考虑\(x\in[0,2]\)的话如何转化\((x_i-x_j)^2\)。将每个向量用一个\(20\)位二进制数\(a\)表示,即\(x_i=0\),则\(a\)的第\(2i-1\)和\(2i\)位为\(00\);\(x_i=1\),第\(2i-1\)和\(2i\)位为\(01\);\(x_i=2\),第\(2i-1\)和\(2i\)位为\(10\)。

这样当\(x_i-x_j\)不同时,对应唯一的\(a_i\ \mathbb{xor}\ a_j\)的结果。所以我们计算\(a_i\ \mathbb{xor}\ a_j\)就能知道差的模长\(|\overrightarrow{V_i}-\overrightarrow{V_j}|\)了。

用\(FWT\)计算\(a_i\ \mathbb{xor}\ a_j=b\)的\((i,j)\)有多少个,再把\(b\)转为模长,就行了。模长最大值是\(40\)。

复杂度\(O(20\times2^{20})\)。


  1. //167ms 6MB
  2. #include <cstdio>
  3. #include <cctype>
  4. #include <algorithm>
  5. #define mod 998244353
  6. #define inv2 499122177
  7. #define Add(x,y) x+y>=mod?x+y-mod:x+y
  8. //#define gc() getchar()
  9. #define MAXIN 500000
  10. #define gc() (SS==TT&&(TT=(SS=IN)+fread(IN,1,MAXIN,stdin),SS==TT)?EOF:*SS++)
  11. typedef long long LL;
  12. const int N=(1<<20)+5,lim=1<<20,ref[]={0,1,4,1};
  13. int A[N],B[50];
  14. char IN[MAXIN],*SS=IN,*TT=IN;
  15. inline int read()
  16. {
  17. int now=0;register char c=gc();
  18. for(;!isdigit(c);c=gc());
  19. for(;isdigit(c);now=now*10+c-48,c=gc());
  20. return now;
  21. }
  22. void FWT(int *a,int opt)
  23. {
  24. for(int i=2; i<=lim; i<<=1)
  25. for(int j=0,mid=i>>1; j<lim; j+=i)
  26. for(int k=j; k<j+mid; ++k)
  27. {
  28. int x=a[k],y=a[k+mid];
  29. a[k]=Add(x,y), a[k+mid]=Add(x,mod-y);
  30. if(opt==-1) a[k]=1ll*a[k]*inv2%mod, a[k+mid]=1ll*a[k+mid]*inv2%mod;
  31. }
  32. }
  33. int main()
  34. {
  35. const int n=read();
  36. for(int i=1; i<=n; ++i)
  37. {
  38. int a=0;
  39. for(int j=0; j<10; ++j)
  40. switch(read())
  41. {
  42. case 0: a<<=2; break;
  43. case 1: a<<=2, a|=1; break;//先左移再或。。
  44. case 2: a<<=2, a|=2; break;
  45. }
  46. ++A[a];
  47. }
  48. FWT(A,1);
  49. for(int i=0; i<lim; ++i) A[i]=1ll*A[i]*A[i]%mod;
  50. FWT(A,-1);
  51. for(int i=0; i<lim; ++i)
  52. {
  53. if(!A[i]) continue;
  54. int res=0;
  55. for(int x=i; x; x>>=2) res+=ref[x&3];
  56. B[res]=Add(B[res],A[i]);
  57. }
  58. LL ans=0;
  59. for(int i=0; i<=40; ++i) ans+=1ll*B[i]*B[i]%mod;
  60. printf("%lld\n",ans%mod);
  61. return 0;
  62. }

Wannafly Winter Camp 2019.Day 8 div1 I.岸边露伴的人生经验(FWT)的更多相关文章

  1. Wannafly Winter Camp 2019.Day 8 div1 E.Souls-like Game(线段树 矩阵快速幂)

    题目链接 \(998244353\)写成\(99824435\)然后调这个线段树模板1.5h= = 以后要注意常量啊啊啊 \(Description\) 每个位置有一个\(3\times3\)的矩阵, ...

  2. 2019 wannafly winter camp day5-8代码库

    目录 day5 5H div2 Nested Tree (树形dp) 5F div2 Kropki (状压dp) 5J div1 Special Judge (计算几何) 5I div1 Sortin ...

  3. 2019 wannafly winter camp day 3

    2019 wannafly winter camp day 3 J 操作S等价于将S串取反,然后依次遍历取反后的串,每次加入新字符a,当前的串是T,那么这次操作之后的串就是TaT.这是第一次转化. 涉 ...

  4. 2019 wannafly winter camp

    2019 wannafly winter camp Name Rank Solved A B C D E F G H I J K day1 9 5/11 O O O O O day2 5 3/11 O ...

  5. 2020 CCPC Wannafly Winter Camp Day1 C. 染色图

    2020 CCPC Wannafly Winter Camp Day1 C. 染色图 定义一张无向图 G=⟨V,E⟩ 是 k 可染色的当且仅当存在函数 f:V↦{1,2,⋯,k} 满足对于 G 中的任 ...

  6. Wannafly Winter Camp Day8(Div1,onsite) E题 Souls-like Game 线段树 矩阵乘法

    目录 Catalog Solution: (有任何问题欢迎留言或私聊 && 欢迎交流讨论哦 Catalog @ Problem:传送门  Portal  原题目描述在最下面.  简单的 ...

  7. 2019 wannafly winter camp day1-4代码库

    目录 day1 F div1 爬爬爬山 (最短路) B div2 吃豆豆 (dp) J div2 夺宝奇兵(暴力) J div1 夺宝奇兵 (权值线段树) C div1 拆拆拆数 E div1 流流流 ...

  8. Wannafly Winter Camp Day5 Div1 E题 Fast Kronecker Transform 转化为NTT或FFT

    目录 Catalog Solution: (有任何问题欢迎留言或私聊 && 欢迎交流讨论哦 Catalog @ Problem:传送门  原题目描述在最下面.  对给定的式子算解.   ...

  9. CCPC Wannafly Winter Camp Div2 部分题解

    Day 1, Div 2, Prob. B - 吃豆豆 题目大意 wls有一个\(n\)行\(m\)列的棋盘,对于第\(i\)行第\(j\)列的格子,每过\(T[i][j]\)秒会在上面出现一个糖果, ...

随机推荐

  1. Fiddler抓包2-只抓APP的请求

    前言 fiddler抓手机app的请求,估计大部分都会,但是如何只抓来自app的请求呢? 把来自pc的请求过滤掉,因为请求太多,这样会找不到重要的信息了. 环境准备: 1.电脑上已装fiddler 2 ...

  2. sqoop无法导出parquet文件到mysql

    1.问题描述 在CDH集群中我们需要将Hive表的数据导入到RDBMS数据库中,使用Sqoop工具可以方便的将Hive表数据抽取到RDBMS数据库中,在使用Sqoop抽取Hive Parquet表时作 ...

  3. 一个kubeadm.config文件--定义了token,扩展了默认端口,外部ETCD集群,自定义docker仓库,基于ipvs的kubeproxy

    这个版本是基于kubeadm.k8s.io/v1alpha3的,如果到了beta1,可能还要变动呢. apiVersion: kubeadm.k8s.io/v1alpha3 kind: InitCon ...

  4. 一脸懵逼学习Zookeeper(动物园管理员)---》高度可靠的分布式协调服务

    1:Zookeeper是一个分布式协调服务:就是为用户的分布式应用程序提供协调服务 A.zookeeper是为别的分布式程序服务的 B.Zookeeper本身就是一个分布式程序(只要有半数以上节点存活 ...

  5. shell 写的 jrottenberg/ffmpeg 转码

    #!/bin/bash ];then echo "The argument must be 2" exit; else echo "$1 $2" fi VIDE ...

  6. [转] 对Array.prototype.slice.call()方法的理解

    在看别人代码时,发现有这么个写法:[].slice.call(arguments, 0),这到底是什么意思呢? 1.基础 1)slice() 方法可从已有的数组中返回选定的元素. start:必需.规 ...

  7. [转] Web前端开发工程师常用技术网站整理

    1.常用工具相关 有道云笔记 http://note.youdao.com/signIn/index.html 36镇-最好用的共享收藏夹 http://www.36zhen.com/ 浏览器同步测试 ...

  8. [转] Mongoose简要API

    Mongoose是在node.js环境下对mongodb进行便捷操作的对象模型工具 因此,要使用mongoose,则必须安装node.js环境以及mongodb数据库.mongoose使mongodb ...

  9. [转] UniCode编码表

    Unicode编码则是采用双字节16位来进行编号,可编65536字符,基本上包含了世界上所有的语言字符,它也就成为了全世界一种通用的编码,而且用十六进制4位表示一个编码,非常简结直观,为大多数开发者所 ...

  10. 自定义rem

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...