题目大意

  这是一道通信题。

  给你 \(8\) 个 \(32\) 位整数。加密端要把这些数加密成至少 \(1000\) 个 \(32\) 位整数,交互库会把这些整数随机打乱后发给解密端,解密端最多能获得其中 \(lim\) 个的值,解密端要按顺序给出这 \(8\) 个整数。

  交互库会测试 \(100\) 次。

  对于 \(lim\geq 50\) 的测试点,要求 \(100\%\) 的正确率。

  对于 \(lim\geq 20\) 的测试点,要求 \(90\%\) 的正确率。

  对于 \(lim\geq 17\) 的测试点,要求 \(50\%\) 的正确率。

题解

解法一

  先把这些数拆成 \(16\) 个 \(16\) 位整数。

  然后每次随机选一些数异或到一起,前 \(16\) 位为这些数的异或值,后 \(16\) 位为选了那些数。

  解密端随机 \(lim\) 个数,求出这些数能不能解出原来的 \(16\) 个数。

  如果 \(lim\times 16\) 的矩阵满秩就能求出。

  \(17\times 16\) 的矩阵满秩的概率约为 \(58\%\)。

  \(20\times 16\) 的矩阵满秩的概率约为 \(94\%\)。

  \(50\times 16\) 的矩阵满秩的概率约为 \(100\%\)。

解法二

  还是先把这些数拆成 \(16\) 个 \(16\) 位整数,记为 \(a_0,a_1,\ldots,a_{15}\)。

  记 \(f(x)=\sum_{i=0}^{15}a_ix^i\)。

  取一个合适大小的整数 \(p\)。

  对于 \(0\leq i<1000\),返回 \(i+(f(i)\bmod p)\times 1000\)。

  解密端随便选 \(16\) 个数就能插值插出 \(a_0,a_1,\ldots,a_{15}\)。

  正确率为 \(100\%\)。

代码

解法一

#include<vector>
#include<algorithm>
using namespace std;
vector<int>encode(vector<int>arr,int lim)
{
static unsigned a[100];
for(int i=0;i<16;i++)
a[i]=0;
for(int i=0;i<8;i++)
{
unsigned v=arr[i];
a[i*2]=v&((1<<16)-1);
a[i*2+1]=v>>16;
}
for(int i=0;i<16;i++)
a[i]|=1<<(i+16);
vector<int>vec;
for(int i=0;i<1<<16;i++)
{
unsigned s=0;
for(int j=0;j<16;j++)
if((i>>j)&1)
s^=a[j];
vec.push_back(s);
}
return vec;
}
static unsigned seed=1932532;
static unsigned get()
{
seed^=seed<<13;
seed^=seed>>17;
seed^=seed<<5;
return seed;
}
vector<int>decode(int(*const arr)(int),int n,int lim){
static unsigned a[100],b[1000000],c[1000000];
for(int i=0;i<1<<16;i++)
c[i]=i;
for(int i=0;i<1<<16;i++)
{
int y=get()%(i+1);
if(y!=i)
swap(c[i],c[y]);
}
for(int i=0;i<lim;i++)
b[i]=arr(c[i]);
vector<int>vec;
for(int i=0;i<16;i++)
{
int x=lim;
for(int j=i;j<lim;j++)
if(b[j]&(1<<(16+i)))
{
x=j;
break;
}
if(x>=lim)
{
for(int i=0;i<8;i++)
vec.push_back(0);
return vec;
}
if(x!=i)
swap(b[x],b[i]);
for(int j=0;j<lim;j++)
if(j!=i&&(b[j]&(1<<(16+i))))
b[j]^=b[i];
}
for(int i=0;i<16;i++)
b[i]&=(1<<16)-1;
for(int i=0;i<8;i++)
vec.push_back((b[i*2+1]<<16)|b[i*2]);
return vec;
}

解法二

#include<vector>
#include<algorithm>
using namespace std;
typedef long long ll;
static const ll p=100003;
vector<int>encode(vector<int>arr,int lim)
{
static unsigned a[100];
for(int i=0;i<16;i++)
a[i]=0;
for(int i=0;i<8;i++)
{
unsigned v=arr[i];
a[i*2]=v&((1<<16)-1);
a[i*2+1]=v>>16;
}
vector<int> vec;
for(int i=0;i<1000;i++)
{
ll s=0;
for(int j=15;j>=0;j--)
s=(s*i+a[j])%p;
vec.push_back(i+s*1000);
}
return vec;
}
static ll fp(ll a,ll b)
{
ll s=1;
for(;b;b>>=1,a=a*a%p)
if(b&1)
s=s*a%p;
return s;
}
vector<int>decode(int(*const arr)(int),int n,int lim){
static unsigned a[100],b[100];
static ll x[1000],y[1000],ans[1000],e[1000];
for(int i=0;i<16;i++)
{
b[i]=arr(i);
x[i]=b[i]%1000;
y[i]=b[i]/1000;
}
for(int i=0;i<16;i++)
ans[i]=0;
for(int i=0;i<16;i++)
{
for(int j=0;j<16;j++)
e[j]=0;
e[0]=1;
for(int j=0;j<16;j++)
if(j!=i)
{
for(int k=15;k>=0;k--)
{
e[k+1]=(e[k+1]+e[k])%p;
e[k]=-e[k]*x[j]%p;
}
}
ll s=y[i];
for(int j=0;j<16;j++)
if(j!=i)
s=s*fp(x[i]-x[j],p-2)%p;
for(int j=0;j<16;j++)
{
e[j]=e[j]*s%p;
ans[j]=(ans[j]+e[j])%p;
}
}
for(int i=0;i<16;i++)
a[i]=(ans[i]+p)%p;
vector<int>vec;
for(int i=0;i<8;i++)
vec.push_back((a[i*2+1]<<16)|a[i*2]);
return vec;
}

【XSY3309】Dreamweaver 高斯消元 拉格朗日插值的更多相关文章

  1. BZOJ3601 一个人的数论 莫比乌斯反演、高斯消元/拉格朗日插值

    传送门 题面图片真是大到离谱-- 题目要求的是 \(\begin{align*}\sum\limits_{i=1}^N i^d[gcd(i,n) == 1] &= \sum\limits_{i ...

  2. UVALive 7138 The Matrix Revolutions(Matrix-Tree + 高斯消元)(2014 Asia Shanghai Regional Contest)

    题目链接:https://icpcarchive.ecs.baylor.edu/index.php?option=com_onlinejudge&Itemid=8&category=6 ...

  3. CF917D Stranger Trees【矩阵树定理,高斯消元】

    题目链接:洛谷 题目大意:给定一个$n$个节点的树$T$,令$ans_k=\sum_{T'}[|T\cap T'|=k]$,即有$k$条边重合.输出$ans_0,ans_1,\ldots,ans_{n ...

  4. 【BZOJ-3143】游走 高斯消元 + 概率期望

    3143: [Hnoi2013]游走 Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 2264  Solved: 987[Submit][Status] ...

  5. 【BZOJ-3270】博物馆 高斯消元 + 概率期望

    3270: 博物馆 Time Limit: 30 Sec  Memory Limit: 128 MBSubmit: 292  Solved: 158[Submit][Status][Discuss] ...

  6. *POJ 1222 高斯消元

    EXTENDED LIGHTS OUT Time Limit: 1000MS   Memory Limit: 10000K Total Submissions: 9612   Accepted: 62 ...

  7. [bzoj1013][JSOI2008][球形空间产生器sphere] (高斯消元)

    Description 有一个球形空间产生器能够在n维空间中产生一个坚硬的球体.现在,你被困在了这个n维球体中,你只知道球 面上n+1个点的坐标,你需要以最快的速度确定这个n维球体的球心坐标,以便于摧 ...

  8. hihoCoder 1196 高斯消元·二

    Description 一个黑白网格,点一次会改变这个以及与其连通的其他方格的颜色,求最少点击次数使得所有全部变成黑色. Sol 高斯消元解异或方程组. 先建立一个方程组. \(x_i\) 表示这个点 ...

  9. BZOJ 2844 albus就是要第一个出场 ——高斯消元 线性基

    [题目分析] 高斯消元求线性基. 题目本身不难,但是两种维护线性基的方法引起了我的思考. void gauss(){ k=n; F(i,1,n){ F(j,i+1,n) if (a[j]>a[i ...

随机推荐

  1. Flutter 即学即用系列博客——09 MethodChannel 实现原生与 Flutter 通信(二)

    前言 上一篇我们讲解了如何通过 EventChannel 实现 Android -> Flutter 的通信. 并且也看到了 Flutter 内部 EventChannel 源码也是对 Meth ...

  2. 使用Aspose.Words将Word文档转换为Tiff格式图片文件

    用Aspose组件的优点是操作Word文档不需要安装Office就可以实现. 首先需要引用Aspose.Words.dll,链接地址:链接:https://pan.baidu.com/s/1rJvjp ...

  3. SpringBoot2.0整合Redis

    Spring Boot2.0在2018年3月份正式发布,相比1.0还是有比较多的改动,例如SpringBoot 自2.0起支持jdk1.8及以上的版本.第三方类库升级.响应式 Spring 编程支持等 ...

  4. mysql判断条件不存在插入存在更新某字段

    insert into mst_sequence(seq_type, seq_desc, seq_date, seq_no, create_time) VALUES('CK', 'XXX', NOW( ...

  5. C++系列总结——多态

    前言 封装隐藏了类内部细节,通过继承加虚函数的方式,我们还可以做到隐藏类之间的差异,这就是多态(运行时多态).多态意味一个接口有多种行为,今天就来说说C++的多态是怎么实现的. 编译时多态感觉没什么好 ...

  6. Java:配置环境(Mac)——Eclipse;修改JDK版本后,Eclipse打不开

    1.官网下载 选择一个速度快的镜像 推荐东软这个 2.双击下载的安装包,下一步 其中有一步是选择Eclipse版本,SE选第一个,EE第二个.仔细审题吧. 3.配置JDK 应用.关闭 4.测试:写个H ...

  7. SQL学习笔记---非select操作

    非select命令 数据库 1.创建     //create database 库名 2.删除     //drop database 库名,... 2.重命名//exec sp_renamedb ...

  8. sql语句修改字段类型和增加字段

    /*修改字段类型*/ ) go /*增加字段和说明*/ ) EXECUTE sp_addextendedproperty N'MS_Description','说明文字',N'user',N'dbo' ...

  9. struct导入项目工程时工程旁边出现红色的×号

    在我们学习java的过程中难免要导入java工程项目,那么当我们导进去的时候出现错误怎么办呢, 一,首先 二,其次 选择Properties 三,再选择 四,再选择 (高版本的选择1.5尽量用1.6的 ...

  10. Python:time模块/random模块/os模块/sys模块

    time 模块 #常用方法 1.time.sleep(secs) (线程)推迟指定的时间运行.单位为秒. 2.time.time() 获取当前时间戳 python中时间日期格式化符号: %y 两位数的 ...