当前位置: 首页 > wzjs >正文

wordpress性能检测温州企业网站排名优化

wordpress性能检测,温州企业网站排名优化,wordpress5安装,平阳做网站【题目链接】 ybt 1551:维护序列 【题目考点】 1. 线段树 区间修改 区间查询 【解题思路】 本题与洛谷 P3373 【模板】线段树 2大体相同,只有输入输出格式略有不同,具体解析请见上题的博文。 【题解代码】 解法1:线段树 …

【题目链接】

ybt 1551:维护序列

【题目考点】

1. 线段树
  • 区间修改 区间查询

【解题思路】

本题与洛谷 P3373 【模板】线段树 2大体相同,只有输入输出格式略有不同,具体解析请见上题的博文。

【题解代码】

解法1:线段树

#include<bits/stdc++.h>
using namespace std;
#define N 100005
#define ADD 1
#define MUL 2
struct Node
{int l, r, m, val, tagAdd, tagMul;
} tree[4*N];
int n, p, m, a[N];
void pushUp(int i)
{tree[i].val = (tree[2*i].val+tree[2*i+1].val)%p;
}
void build(int i, int l, int r)
{tree[i].l = l, tree[i].r = r, tree[i].m = l+r>>1, tree[i].tagMul = 1;if(l == r){tree[i].val = a[l];return;}build(2*i, l, tree[i].m);build(2*i+1, tree[i].m+1, r);pushUp(i);
}
void addTag(int type, int i, long long v)//v设为long long保证下面的运算都是long long类型的 
{if(type == ADD){tree[i].tagAdd = (tree[i].tagAdd+v)%p;tree[i].val = (tree[i].val+(tree[i].r-tree[i].l+1)*v)%p;}else //type == MUL{tree[i].tagMul = tree[i].tagMul*v%p;tree[i].tagAdd = tree[i].tagAdd*v%p;//增加的值也乘v tree[i].val = tree[i].val*v%p;}
}
void pushDown(int i)//只有在tagAdd和tagMul二者只有其一时,才能下传 
{if(tree[i].tagAdd == 0 && tree[i].tagMul == 1)return;addTag(MUL, 2*i, tree[i].tagMul);//必须先乘后加 addTag(MUL, 2*i+1, tree[i].tagMul);addTag(ADD, 2*i, tree[i].tagAdd);addTag(ADD, 2*i+1, tree[i].tagAdd);tree[i].tagAdd = 0, tree[i].tagMul = 1;
}
void update(int type, int i, int l, int r, int v)
{if(tree[i].r < l || tree[i].l > r)return;if(l <= tree[i].l && tree[i].r <= r){addTag(type, i, v);return;}pushDown(i);update(type, 2*i, l, r, v);update(type, 2*i+1, l, r, v);pushUp(i);
}
int query(int i, int l, int r)
{if(tree[i].r < l || tree[i].l > r)return 0;if(l <= tree[i].l && tree[i].r <= r)return tree[i].val;pushDown(i);return (query(2*i, l, r) + query(2*i+1, l, r))%p;
}
int main()
{ios::sync_with_stdio(false);cin.tie(nullptr);int op, t, g, c;cin >> n >> p;for(int i = 1; i <= n; ++i)cin >> a[i];cin >> m;build(1, 1, n);while(m--){cin >> op;if(op == 1){cin >> t >> g >> c;update(MUL, 1, t, g, c);}else if(op == 2){cin >> t >> g >> c;update(ADD, 1, t, g, c);}else{cin >> t >> g;cout << query(1, t, g) << '\n';}}return 0;
}
http://www.dtcms.com/wzjs/146432.html

相关文章:

  • 做网站版权所有怎么写百度官网网站
  • 灵山招聘网灵山英才网做灵山专业的招聘网站seo入门到精通
  • 汽车专业网站郑州纯手工seo
  • 建网站设郑州seo网络推广
  • 上海地产网站建设如何开展网络营销
  • c 网站做微信收款功能商城网站开发公司
  • 商丘至开网络科技有限公司林哥seo
  • 网上学编程的有哪些比较好的网站软件培训机构有哪些?哪个比较好
  • 网站源码论坛网上营销是干什么的
  • ftp和网站后台百度刷自己网站的关键词
  • 网站建设维护的相关基础知识seo就业哪家好
  • 首钢建设工资网站外链查询工具
  • 长宁区网站建设网站制作网络舆情管控
  • 营销网站开发公司网店推广的方式
  • 外卖网站建设方案书网站不收录怎么办
  • 搬瓦工做网站谷歌优化seo
  • 信息聚合网站怎么做国外域名注册
  • 思淘网站建设建网站软件
  • 动漫网站htmlseo优化轻松seo优化排名
  • 陕西网站建设电话站长统计幸福宝2022年排行榜
  • 南昌哪里有网站建设百度官方电话
  • 那些网站做任务领q币百度指数名词解释
  • 好男人好资源影视在线网站优化公司排名
  • 网站建设方案书个人郑州网站推广培训
  • 长治做网站多少钱游戏推广员每天做什么
  • 教新手做网站难吗搜索引擎优化的方法有哪些?
  • 深圳计算机速成班培训久久seo综合查询
  • 淘宝返利网站怎么做的杭州网站排名seo
  • 咸宁网网站南京市网站seo整站优化
  • seo实训报告seo技术培训