【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个位置排成一排,每个位置可以摆花也可以不摆花.有些花如果摆在相邻的位置(隔着一个空的位置不算相邻),就不好看 ...
随机推荐
- 免考final linux提权与渗透入门——Exploit-Exercise Nebula学习与实践
免考final linux提权与渗透入门--Exploit-Exercise Nebula学习与实践 0x0 前言 Exploit-Exercise是一系列学习linux下渗透的虚拟环境,官网是htt ...
- 毕业 迷茫 继续OR放弃?
终于还是回学校拿了毕业证书,请了两个小时的假,连同中午吃饭的时间,顺利地从班主任手中拿到了毕业证书,大学就这样结束啦,人生也来到了一个新的转折点,但是每天的每天,我都是异常迷茫,异常胆怯,异常无语. ...
- Mac iTem2 自动登录服务器配置
假设你要连接的服务器地址为123.123.123.123,端口号为8888,用户名为root,密码为mimamima 编写shell文件"login_server.sh",并放置于 ...
- 聊聊Bug引发事故该不该追求责任
最近读极客时间朱赟的一篇文章有感,在这也聊一下,在互联网的公司大多数以迭代的方式上线需求,节奏一般都比较快,经常会一个需求当天来了第二天就上线,开发和测试时间总共就两天,中间还穿插着别的需求测试,不像 ...
- Python递归算法入门
递归是一种算法,它在编程里面有着广泛的应用: 1. 递归必须满足哪两个基本条件? 一.函数调用自身 二.设置了正确的返回条件 2. 思考一下,按照递归的特性,在编程中有没有不得不使用递归的情况? 答: ...
- C#冒泡排序法及优化
冒泡排序法及优化: static void Main(string[] args) { , , , , , }; ; //冒泡排序法 ; i < sums.Length - ; i++) //总 ...
- 【setUp-tearDown】线程组开始,结束各执行一次
使用setUp线程组的方式 ——> 开始 使用tearDown线程组 的方式 ——>结束
- Memcache的客户端连接系列(四) PHP
关键词: Memcached PHP 客户端 声明:本文并非原创,转自华为云帮助中心的分布式缓存服务(Memcached)的用户指南.客户端连接方法通用,故摘抄过来分享给大家. PHP客户端 Re ...
- matlab中设置colorbar为几种规定颜色
我们可以通过修改colormap的值来达到这种目的. 一般来说colormap的值是64*3的矩阵,64代表64种颜色,3列是这种颜色的RGB值,不过归一化了. 如果你想将colorbar颜色设成6种 ...
- CryptoZombies学习笔记——Lesson5
chapter1:token代币 简而言之,通证就是支持交易的包含一系列规范的函数接口的一个智能合约,发币可以用ERC20标准,但是像僵尸这种非同质化代币,需要用ERC721标准 chapter2:e ...