【bzoj1712】[Usaco2007 China]Summing Sums 加密 矩阵乘法
题目描述
.jpg)
输入
输出
样例输入
3 4
1
0
4
样例输出
26
25
29
题解
矩阵乘法
令原数和加密后的数构成一个矩阵,设矩阵a为[ci,sum-ci],则加密一次后的矩阵A为[sum-ci,(n-1)sum-(sum-ci)],
因为显而易见所有数加密一次后总和变为原来的n-1倍。
推出a乘矩阵[[0,n-1],[1,n-2]]可以得到A,设这个矩阵为b。
按照这个规律,加密T次和T+1次构成的矩阵为a*bt。
对于每个数,处理出矩阵a,就可以用快速幂解决a*bt,得到加密t次的数。
注意要开long long
#include <cstdio>
#include <cstring>
#define MOD 98765431
typedef long long lint;
struct matrix
{
int x , y;
lint num[3][3];
matrix operator*(const matrix a) const
{
matrix t;
int i , j , k;
memset(t.num , 0 , sizeof(t.num));
t.x = x , t.y = a.y;
for(i = 1 ; i <= t.x ; i ++ )
for(j = 1 ; j <= t.y ; j ++ )
for(k = 1 ; k <= y ; k ++ )
t.num[i][j] = (t.num[i][j] + num[i][k] * a.num[k][j]) % MOD;
return t;
}
}a , b;
lint c[50010];
matrix qpow(matrix a , int b)
{
matrix t;
int i;
t.x = a.x , t.y = a.y;
memset(t.num , 0 , sizeof(t.num));
for(i = 1 ; i <= t.x ; i ++ )
t.num[i][i] = 1;
while(b)
{
if(b & 1)
t = t * a;
a = a * a;
b >>= 1;
}
return t;
}
int main()
{
int n , t , i;
lint sum = 0;
scanf("%d%d" , &n , &t);
for(i = 1 ; i <= n ; i ++ )
scanf("%lld" , &c[i]) , sum = (sum + c[i]) % MOD;
b.x = b.y = 2;
b.num[1][1] = 0 , b.num[1][2] = n - 1 , b.num[2][1] = 1 , b.num[2][2] = n - 2;
b = qpow(b , t);
a.x = 1 , a.y = 2;
for(i = 1 ; i <= n ; i ++ )
{
a.num[1][1] = c[i] , a.num[1][2] = (sum - c[i] + MOD) % MOD;
printf("%lld\n" , (a * b).num[1][1]);
}
return 0;
}
【bzoj1712】[Usaco2007 China]Summing Sums 加密 矩阵乘法的更多相关文章
- BZOJ1712 : [Usaco2007 China]Summing Sums 加密
设$s[i]$为进行$i$次加密后所有奶牛数字的和,有$s[i]=(n-1)s[i-1]$. 设$c[i]$为某头固定的奶牛进行$i$次加密后的数字, 若$i$为奇数,有: \[c[i]=((1-n) ...
- BZOJ_1712_[Usaco2007 China]Summing Sums 加密_矩阵乘法
BZOJ_1712_[Usaco2007 China]Summing Sums 加密_矩阵乘法 Description 那N只可爱的奶牛刚刚学习了有关密码的许多算法,终于,她们创造出了属于奶牛 ...
- bzoj 1712: [Usaco2007 China]Summing Sums 加密
1712: [Usaco2007 China]Summing Sums 加密 Description 那N只可爱的奶牛刚刚学习了有关密码的许多算法,终于,她们创造出了属于奶牛的加密方法.由于她 ...
- 1712: [Usaco2007 China]Summing Sums 加密
1712: [Usaco2007 China]Summing Sums 加密 Time Limit: 5 Sec Memory Limit: 64 MBSubmit: 338 Solved: 12 ...
- 【BZOJ1706】[usaco2007 Nov]relays 奶牛接力跑 矩阵乘法
[BZOJ1706][usaco2007 Nov]relays 奶牛接力跑 Description FJ的N(2 <= N <= 1,000,000)头奶牛选择了接力跑作为她们的日常锻炼项 ...
- 倍增&矩阵乘法 专题复习
倍增&矩阵乘法 专题复习 PreWords 这两个基础算法我就不多说啦,但是还是要介绍一下" 广义矩阵 "乘法 其实就是把矩阵换成取\(max\),然后都一样... 据神仙 ...
- *HDU2254 矩阵乘法
奥运 Time Limit: 1000/1000 MS (Java/Others) Memory Limit: 65536/65536 K (Java/Others)Total Submissi ...
- *HDU 1757 矩阵乘法
A Simple Math Problem Time Limit: 3000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Ot ...
- CH Round #30 摆花[矩阵乘法]
摆花 CH Round #30 - 清明欢乐赛 背景及描述 艺术馆门前将摆出许多花,一共有n个位置排成一排,每个位置可以摆花也可以不摆花.有些花如果摆在相邻的位置(隔着一个空的位置不算相邻),就不好看 ...
随机推荐
- create a nodejs npm package
1. create a folder named m1 2. run command: npm init, this will create the package.json file 3. crea ...
- Java设计模式(20)——行为模式之命令模式(Command)
一.概述 概念 类似C中的callback! UML简图 角色 客户端:创建具体命令,指定接收者 命令接口:声明命令的接口 具体命令:定义接收者和行为之间的弱耦合(execute执行方法) 请求者(I ...
- 【转】Odoo开发之:工作流 workflow
在OpenERP中,工作流是管理一组“所做的事情”(与一些数据模型的记录关联)的人为现象.工作流提供了高级别的方式来组织记录要上做的事情. 具体地说,工作流是一个定向的路径,这里节点称为活动并且弧线称 ...
- 北京Uber优步司机奖励政策(3月14日)
滴快车单单2.5倍,注册地址:http://www.udache.com/ 如何注册Uber司机(全国版最新最详细注册流程)/月入2万/不用抢单:http://www.cnblogs.com/mfry ...
- spring之HttpInvoker
一.HttpInvoker是常用的Java同构系统之间方法调用实现方案,是众多Spring项目中的一个子项目.顾名思义,它通过HTTP通信即可实现两个Java系统之间的远程方法调用,使得系统之间的通信 ...
- MySQL高级-索引优化
索引失效 1. 2.最佳左前缀法则 4. 8. 使用覆盖索引解决这个问题. 二.索引优化 1.ORDER BY 子句,尽量使用Index方式排序,避免使用FileSort方式排序 MySQL支持两种方 ...
- iOS性能调优工具
总结: 三类工具 基础工具 (NSLog的方式记录运行时间.) 性能工具.检测各个部分的性能表现,找出性能瓶颈 内存工具.检查内存正确性和内存使用效率 性能工具: 可以衡量CPU的使用,时间的消耗,电 ...
- ElasticSearch搜索引擎安装配置中文分词器IK插件
近几篇ElasticSearch系列: 1.阿里云服务器Linux系统安装配置ElasticSearch搜索引擎 2.Linux系统中ElasticSearch搜索引擎安装配置Head插件 3.Ela ...
- 【label】标签组件说明
label标签组件 用来改进表单组件的可用性,使用for属性找到对应的id,或者将控件放在该标签下,当点击时,就会触发对应的控件.目前可以绑定的控件有:<button/>, <che ...
- 【WXS数据类型】Number
Number包括整数与小数. 属性: 名称 返回 说明 [Number].constructor 值为字符串“Number” 返回该类型的结构字符串 方法: 原型:[Number].toString( ...