【NOIP模拟】matrix(简化矩阵)
题目背景
SOURCE:NOIP2016-RZZ-1
题目描述
给出两个 N×N 的矩阵 A、B,矩阵每行每列标号 0~N-1 。
定义这两个矩阵的乘积 AB 为
aaarticlea/png;base64,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" alt="" />
现在要在这两个矩阵上依次进行 Q 次修改操作,两种操作描述如下:
- A i j K ,将 Ai,j 的值修改为 K 。
- B i j K ,将 Bi,j 的值修改为 K 。
在每一次修改操作进行后,输出矩阵 AB(这两个矩阵的乘积矩阵)中每个位置元素的权值之和。
输入格式
第一行,一个正整数 N ,表示矩阵的大小。
接下来 N 行,每行 N 个整数,描述矩阵 A 。
接下来 N 行,每行 N 个整数,描述矩阵 B 。
接下来一行,一个正整数 Q ,表示操作次数。
接下来 Q 行,每行描述一个操作,格式如题面所示。
输出格式
输出 Q 行,每行一个整数,表示这次操作完成后的答案。
样例数据 1
输入
2
1 2
3 4
4 3
2 1
3
A 1 1 2
B 0 1 3
A 0 0 10
输出
40
40
103
备注
【数据规模与约定】
对于 10% 的数据,N = 1。对于 30% 的数据,N,Q≤10。对于 80% 的数据,1≤N≤100,|Ai,j|,|Bi,j|≤10。
对于 100% 的数据,1≤N≤1000,1≤Q≤105,|Aij|,|Bi,j|≤1000。
【题目分析】
矩阵乘法的答案矩阵中的$(i, j)$为:矩阵$1$的第$i$行中的每个数$(i, k)$,乘上矩阵$2$中第j列的每一个数$(k, j)$
所以要求每次操作的答案,只需要记录一个$sum1[i]$表示矩阵$1$中第$i$列的和,和$sum2[i]$表示矩阵$2$中第$i$行的和,和$sum$表示答案矩阵的和。
修改矩阵$1$中的$(i, j)$时,$sum$只需加上$delta × sum2[i]$
修改矩阵$2$中的$(i, j)$时, $sum$只需加上$delta × sum1[j]$即可。
【CODE】
#include<iostream>
#include<cstdio>
#include<cstdlib>
#include<cstring>
#include<string>
#include<cmath>
#include<algorithm>
#include<vector>
using namespace std; typedef long long ll;
const int N = ;
ll all, sum1[N], sum2[N];
int a[N][N], b[N][N];
int n, Q; inline int Re(){
int i = , f = ; char ch = getchar();
for(; (ch < '' || ch > '') && ch != '-'; ch = getchar());
if(ch == '-') f = -, ch = getchar();
for(; ch >= '' && ch <= ''; ch = getchar())
i = (i << ) + (i << ) + (ch - '');
return i * f;
} inline void Wr(ll x){
if(x < ) putchar('-'), x = -x;
if(x > ) Wr(x / );
putchar(x % + '');
} int main(){
// freopen("matrix.in", "r", stdin);
// freopen("matrix.out", "w", stdout);
n = Re();
for(int i = ; i <= n; i++)
for(int j = ; j <= n; j++)
a[i][j] = Re(),
sum1[j] += (ll)a[i][j];
for(int i = ; i <= n; i++)
for(int j = ; j <= n; j++)
b[i][j] = Re(),
sum2[i] += (ll)b[i][j],
all += 1LL * sum1[i] * b[i][j];
// for(int i = 1; i <= n; i++) cout<<sum1[i]<<" "<<sum2[i]<<endl;return 0;
Q = Re();
while(Q--){
char opt;
scanf("%c", &opt);
if(opt == 'A'){
int i = Re() + , j = Re() + , tmp = Re();
sum1[j] += (tmp - (a[i][j]));
all += 1LL * (tmp - (a[i][j])) * sum2[j];
a[i][j] = tmp;
}
else if(opt == 'B'){
int i = Re() + , j = Re() + , tmp = Re();
sum2[i] += (tmp - (b[i][j]));
all += 1LL * (tmp - (b[i][j])) * sum1[i];
b[i][j] = tmp;
}
Wr(all), putchar('\n');
}
return ;
}
【NOIP模拟】matrix(简化矩阵)的更多相关文章
- 2018.10.19 NOIP模拟 硬币(矩阵快速幂优化dp)
传送门 不得不说神仙出题人DZYODZYODZYO出的题是真的妙. f[i][j][k]f[i][j][k]f[i][j][k]表示选的硬币最大面值为iii最小面值不小于jjj,总面值为kkk时的选法 ...
- 2018.08.30 NOIP模拟 kfib(矩阵快速幂+exgcd)
[输入] 一行两个整数 n P [输出] 从小到大输出可能的 k,若不存在,输出 None [样例输入 1] 5 5 [样例输出] 2 [样例解释] f[0] = 2 f[1] = 2 f[2] = ...
- 8.5 NOIP模拟测试13 矩阵游戏+跳房子+优美序列
T1矩阵游戏 数学题.首先这一列这一行先乘还是后乘对最后答案没有影响.a[i][j]表示矩阵中原始的值,h[i]表示i行的累乘,l[i]表示i列的累乘.易得ans=Σa[i][j]*h[i]*l[i] ...
- NOIP模拟赛 by hzwer
2015年10月04日NOIP模拟赛 by hzwer (这是小奇=> 小奇挖矿2(mining) [题目背景] 小奇飞船的钻头开启了无限耐久+精准采集模式!这次它要将原矿运到泛光之源的矿 ...
- 2018.9.22 NOIP模拟赛
*注意:这套题目应版权方要求,不得公示题面. 从这里开始 Problem A 妹子 Problem B 旅程 Problem C 老大 因为业务水平下滑太严重,去和高一考NOIP模拟,sad... P ...
- NOI.AC NOIP模拟赛 第三场 补记
NOI.AC NOIP模拟赛 第三场 补记 列队 题目大意: 给定一个\(n\times m(n,m\le1000)\)的矩阵,每个格子上有一个数\(w_{i,j}\).保证\(w_{i,j}\)互不 ...
- 【入门OJ】2003: [Noip模拟题]寻找羔羊
这里可以复制样例: 样例输入: agnusbgnus 样例输出: 6 这里是链接:[入门OJ]2003: [Noip模拟题]寻找羔羊 这里是题解: 题目是求子串个数,且要求简单去重. 对于一个例子(a ...
- NOIP模拟题汇总(加厚版)
\(NOIP\)模拟题汇总(加厚版) T1 string 描述 有一个仅由 '0' 和 '1' 组成的字符串 \(A\),可以对其执行下列两个操作: 删除 \(A\)中的第一个字符: 若 \(A\)中 ...
- 2014-10-31 NOIP模拟赛
10.30 NOIp 模拟赛 时间 空间 测试点 评测方式 挖掘机(dig.*) 1s 256M 10 传统 黑红树(brtree.*) 2s 256M 10 传统 藏宝图(treas. ...
- 9.9 NOIP模拟题
9.9 NOIP模拟题 T1 两个圆的面积求并 /* 计算圆的面积并 多个圆要用辛普森积分解决 这里只有两个,模拟计算就好 两圆相交时,面积并等于中间两个扇形面积减去两个三角形面积 余弦定理求角度,算 ...
随机推荐
- Java-集合框架总结
集合框架: Java中的集合框架大类可分为Collection和Map:两者的区别: 1.Collection是单列集合:Map是双列集合 2.Collection中只有Set系列要求元素唯一:Map ...
- springboot问题:解决异常Unable to start embedded container;
使用eclipse创建springboot练习时,当主函数与控制器同时写在同一个类时,启动项目正常运行,而当把主函数单独放在一个类中时,无论是与控制器同包还是控制器所在的包是其子包,都报: org.s ...
- MVC分层含义与开发方式
真正的服务层是面向数据的,假想一切数据都是从参数获得 控制层是接受页面层数据,再传给服务层,然后将结果返回给页面层的(客户) 页面层是提交格式化的数据的(容易小混乱,无格式,所以要格式化,可以在中间加 ...
- Chapter 9:Noise-Estimation Algorithms
作者:桂. 时间:2017-06-14 12:08:57 链接:http://www.cnblogs.com/xingshansi/p/6956556.html 主要是<Speech enha ...
- 浅谈JavaScript递归
递归:是指函数/过程/子程序在运行过程序中直接或间接调用自身而产生的重入现象.递归指的是一个过程:函数不断引用自身,直到引用的对象已知. //公园里面有200个桃子,每天吃掉一半,扔掉一个烂的,第6天 ...
- RDLC报表纵向合并单元格。
在做RDLC报表时发现居然没有纵向合并单元格,震惊! 网上查了一些资料,有些方法很可爱,采用去除边框法,但是用这种方法如果要求文本属性居中的话那则达不到美观效果,还有些复杂一点的方法,我都没耐心看,然 ...
- spark streaming(2) DAG静态定义及DStream,DStreamGraph
DAG 中文名有向无环图.它不是spark独有技术.它是一种编程思想 ,甚至于hadoop阵营里也有运用DAG的技术,比如Tez,Oozie.有意思的是,Tez是从MapReduce的基础上深化而来的 ...
- 使用 sitemesh/decorator装饰器装饰jsp页面(原理及详细配置)
摘要:首先这个Decorator解释一下这个单词:“装饰器”,我觉得其实可以这样理解,他就像我们用到的Frame,他把每个页面共有的东西提炼了出来,也可能我们也会用各种各样的include标签,将我们 ...
- css自定义动画在微信中无法执行的原因
这是我去年年底遇到的一个问题, 在这个过程中我发现了一个比较有趣的问题. 我们在做抽奖的时候,微信分享到朋友圈的页面里,安卓机器无法执行页面中的自定义动画(元宝的位移,进入按钮的放大缩小等等).这让我 ...
- Java WebService学习资料
最近用到了WebService,以前没用过,想要好好学习一下.感觉网上资料比较少,而且很杂,找了很久,觉得下面的两个文章解释的比较清楚,分享一下: WebService概念.原理:http://mp. ...