【题解】L 国的战斗续之多路出击 [P2129]
【题解】L 国的战斗续之多路出击 [P2129]
传送门: \(L\) 国的战斗续之多路出击 \([P2129]\)
【题目描述】
给出 \(n\) 个坐标,\(m\) 个指令,指令处理顺序应是从后往前。
求最终的 \(n\) 个坐标。
【输入】
第一行两个整数 \(n,m\) 。
接下来 \(n\) 行,每行两个整数 \(x_i,y_i\) 表示第 \(i\) 个坐标。
然后 \(m\) 行,每行首先一个字符 \(C\),
\((1).\) 若\(C\)为 \(\text{'m'}\),则紧跟两个整数 \(p,q\),要求把所有坐标 \((x_i,y_i)\) 变为 \((x_i+p,y_i+q)\) 。
\((2).\) 若 \(C\) 为 \(\text{'x'}\),则把所有坐标从 \((xi,yi)\) 变为 \((-xi,yi)\)
\((3).\) 若 \(C\) 为 \(\text{'y'}\),则把所有坐标从 \((xi,yi)\) 变为 \((xi,-yi)\) 。
【输出】
【样例】
样例输入:
3 3
0 0
4 -3
6 7
x
m -1 2
y
样例输出:
1 2
-3 5
-5 -5
【数据范围】
\(30 \%:\) \(1 \leqslant n,m \leqslant 1000\)
\(100 \%:\) \(1 \leqslant n,m \leqslant 5*10^5\)
【分析】
大佬们都写的是矩阵乘法或者模拟,向我这种不会矩阵和膜您的蒟蒻就只能写线段树了 \(\text{QAQ}\) (好像是第一个用这种奇葩方法的?)。
区间加,区间乘的模板,但因为是单调查询,而且没有取模这种鬼畜操作,比【模板】线段树 \(2\) 和 维护序列 要简单得多。
维护一个乘法标记 \(mul\) 和加法标记 \(add\),区间加时就直接更新 \(add\),区间乘 \(v\) 就先让 \(mul\) 和 \(add\) 都乘以 \(v\) 。
下传标记时先传 \(mul\) 再传 \(add\)
其他的就直接照着题目模拟就可以了。
坑点:\(m\) 个指令要倒着处理。
【Code】
#include<cstdio>
#define Re register int
#define pl (p<<1)//左儿子
#define pr (p<<1|1)//右儿子
#define mid (L+R>>1)
#define pa tr[p].add//加法标记
#define pm tr[p].mul//乘法标记
const int N=5e5+5;
int n,x,y,T,a[N],b[N];
inline void in(Re &x){
Re f=0;x=0;char c=getchar();
while(c<'0'||c>'9')f|=c=='-',c=getchar();
while(c>='0'&&c<='9')x=(x<<1)+(x<<3)+(c^48),c=getchar();
x=f?-x:x;
}
struct Segment_Tree{
struct QAQ{int l,r,ans,add,mul;}tr[N<<2];
inline void updata_add(Re p,Re v){
if(tr[p].l==tr[p].r)tr[p].ans+=v;//只需要更新叶子节点
pa+=v;//但标记必须下传
}
inline void updata_mul(Re p,Re v){
if(tr[p].l==tr[p].r)tr[p].ans*=v;//同上
pm*=v,pa*=v;
}
inline void pushdown(Re p){//先下传乘法标记,再下传加法标记
if(pm!=1)updata_mul(pl,pm),updata_mul(pr,pm),pm=1;//这里乘法标记也要初始化为1
if(pa)updata_add(pl,pa),updata_add(pr,pa),pa=0;
}
inline void build(Re p,Re L,Re R){//初始化建树
tr[p].l=L,tr[p].r=R,pm=1;//乘标记要初始化为1
if(L==R){tr[p].ans=a[L];return;}
build(pl,L,mid),build(pr,mid+1,R);
}
inline void change_add(Re p,Re l,Re r,Re v){//区间加
Re L=tr[p].l,R=tr[p].r;
if(l<=L&&R<=r){updata_add(p,v);return;}
pushdown(p);
if(l<=mid)change_add(pl,l,r,v);
if(r>mid)change_add(pr,l,r,v);
}
inline void change_mul(Re p,Re l,Re r,Re v){//区间乘
Re L=tr[p].l,R=tr[p].r;
if(l<=L&&R<=r){updata_mul(p,v);return;}
pushdown(p);
if(l<=mid)change_mul(pl,l,r,v);
if(r>mid)change_mul(pr,l,r,v);
}
inline int ask(Re p,Re w){//单点查询
Re L=tr[p].l,R=tr[p].r;
if(L==R)return tr[p].ans;
pushdown(p);
if(w<=mid)return ask(pl,w);
else return ask(pr,w);
}
}T1,T2;//T1:x坐标。T2:y坐标。
inline void sakura(Re T){
Re x,y;char op;
if(!T)return;
scanf(" %c",&op);
if(op=='m')in(x),in(y);
sakura(T-1);
if(op=='x')T1.change_mul(1,1,n,-1);//(x,y) -> (-x,y)
else if(op=='y')T2.change_mul(1,1,n,-1);//(x,y) ->(x,-y)
else T1.change_add(1,1,n,x),T2.change_add(1,1,n,y);//(x,y) -> (x+p,y+q)
}
int main(){
// freopen("123.txt","r",stdin);
in(n),in(T);
for(Re i=1;i<=n;++i)in(a[i]),in(b[i]);
T1.build(1,1,n);//第一棵树
for(Re i=1;i<=n;++i)a[i]=b[i];
T2.build(1,1,n);//第二课树
sakura(T);
for(Re i=1;i<=n;++i)printf("%d %d\n",T1.ask(1,i),T2.ask(1,i));
}
【题解】L 国的战斗续之多路出击 [P2129]的更多相关文章
- 洛谷 P2129 L国的战斗续之多路出击(模拟)
P2129 L国的战斗续之多路出击 题目背景 广而告之:背景见其他L国的战斗!!大家一起刷 题目描述 这一次,L国决定军队分成n组,分布在各地,若以L国为原点,可以看作在一个直角坐标系内.但是他们都受 ...
- P2129 L国的战斗续之多路出击
题目描述 这一次,L国决定军队分成n组,分布在各地,若以L国为原点,可以看作在一个直角坐标系内.但是他们都受统一的指挥,指令部共发出m个命令.命令有移动.上下转移和左右转移(瞬移??),但是由于某些奇 ...
- [luoguP2129] L国的战斗续之多路出击(模拟 || 矩阵)
传送门 1.模拟 easy #include <cstdio> #define N 500001 int n, m; int X[N], Y[N], x[N], y[N], a = 1, ...
- P1910 L国的战斗之间谍
P1910 L国的战斗之间谍 题目背景 L国即将与I国发动战争!! 题目描述 俗话说的好:“知己知彼,百战不殆”.L国的指挥官想派出间谍前往I国,于是,选人工作就落到了你身上. 你现在有N个人选,每个 ...
- AC日记——L国的战斗之间谍 洛谷 P1916
题目背景 L国即将与I国发动战争!! 题目描述 俗话说的好:“知己知彼,百战不殆”.L国的指挥官想派出间谍前往I国,于是,选人工作就落到了你身上. 你现在有N个人选,每个人都有这样一些数据:A(能得到 ...
- 洛谷 P1910 L国的战斗之间谍(水题日常)
题目背景 L国即将与I国发动战争!! 题目描述 俗话说的好:“知己知彼,百战不殆”.L国的指挥官想派出间谍前往I国,于是,选人工作就落到了你身上. 你现在有N个人选,每个人都有这样一些数据:A(能得到 ...
- 洛谷——P1910 L国的战斗之间谍
https://www.luogu.org/problem/show?pid=1910#sub 题目背景 L国即将与I国发动战争!! 题目描述 俗话说的好:“知己知彼,百战不殆”.L国的指挥官想派出间 ...
- 洛谷 P1913 L国的战斗之伞兵
P1913 L国的战斗之伞兵 题目背景 L国即将与I国发动战争!! 题目描述 为了在敌国渗透作战,指挥官决定:派出伞兵前往敌国!然而敌国的风十分强烈,能让伞兵在同一高度不停转悠,直到被刮到一个无风区… ...
- 洛谷 P1911 L国的战斗之排兵布阵
P1911 L国的战斗之排兵布阵 题目背景 L国即将与I国发动战争!! 题目描述 L国的指挥官想让他的每一个军营都呈现出国徽形——“L”形(方向无所谓).当然,他的指挥营除外(这叫做个性),他想不出该 ...
随机推荐
- vue中使用axios进行ajax请求数据(跨域配置)
npm安装axios npm install axios --save 引入axios import axios from 'axios' 使用axios mounted () { this.getH ...
- memory一致性模型
https://homes.cs.washington.edu/~bornholt/post/memory-models.html https://www.cs.cmu.edu/afs/cs/acad ...
- maven 学习---NetBeans IDE集成Maven
NetBeans6.7更新版本已经内置对Maven支持.如遇以前的版本,Maven插件在插件管理器中可用.我们正在使用NetBeans在这个例子中使用6.9. 在NetBeans一些特点如下 您可以从 ...
- 【推荐】全球最全面的Telegram组群频道的集合网站 持续收集中
全球最全面的Telegram组群频道的集合网站 https://www.telegramgroup.org Telegram 组群频道分享 可搜索自己想找的组群频道 从小白到大神,一个 telegra ...
- HeadFirst设计模式---抽象工厂
类图 抽象披萨商店类 public abstract class PizzaStore { public void orderPizza(String type) { AbstractPizza ab ...
- 【洛谷P3973】[TJOI2015]线性代数(最小割)
洛谷 题意: 给出一个\(n*n\)的矩阵\(B\),再给出一个\(1*n\)的矩阵\(C\). 求一个\(1*n\)的\(01\)矩阵\(A\),使得\(D=(A\cdot B-C)\cdot A^ ...
- 201871010117 石欣钰《面向对象程序设计(Java)》第十二周学习总结
内容 这个作业属于哪个课程 https://www.cnblogs.com/nwnu-daizh/ 这个作业的要求在哪里 https://www.cnblogs.com/nwnu-daizh/p/ ...
- django学习-数据库操作接口API--(CRUD)
初试API(数据库操作接口CRUD) 现在我们进入交互式python命令行,尝试一下django为你创建的各种API,通过以下命令打开python命令行: py -3 manage.py shell进 ...
- Ubuntu下apache2安装配置(内含数字证书配置)
Ubuntu下apache2安装配置(内含数字证书配置)安装命令:sudo apt-get updatesudo apt-get install apache2 配置1.查看apache2安装目录命令 ...
- hekaiming专坑
先挖个 图像去雾之何凯明暗通道先验去雾算法原理及c++代码实现 ICCV 2017:FAIR Mask R-CNN ICCV 2017:FAIR 密集物体检测的 Focal Loss one-stag ...