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

定安网站建设中国广告公司前十强

定安网站建设,中国广告公司前十强,如何在淘宝网做自己的网站,云服务器优惠活动传送门:牛客 题目描述: 题目latex公式较多,此处省略 输入: 10 6 1 1 1 2 4 6 1 3 2 2 5 7 1 6 10 2 1 10 输出: 3 5 26这道题让我体验到的线段树相对于树状数组的常数巨大 我们倘若直接用单点修改的话,如果D过小比如1那么我们足足要加n次,时间复杂度爆…

传送门:牛客

题目描述:

题目latex公式较多,此处省略
输入:
10 6
1 1 1
2 4 6
1 3 2
2 5 7
1 6 10
2 1 10
输出:
3
5
26

这道题让我体验到的线段树相对于树状数组的常数巨大

我们倘若直接用单点修改的话,如果D过小比如1那么我们足足要加n次,时间复杂度爆炸。
那如果我们把每次要相加的记录下来lazy[D]+=K那么在我们计算和时

for (int i=1;i<=n;i++)ans+=(b/i - (a-1)/i)*lazy[i]

我们发现我们同样复杂度无法接受

所以对于本题来说,我们需要有一个分块的想法,也就是找一个界限,在界限的两边采用不同的算法,使得我们的总体复杂度可以接受.我们设这个度为S.我们发现我们的模数越大,显然对直接暴力修改时越有利的,因为我们需要修改的点就越小.反之我们应选用记录lazy的方式

那么对于第一种方法来说,我们的最坏复杂度为n/S∗logn∗mn/S*logn*mn/Slognm
对于第二种方法来说,我们的最坏复杂度为S∗mS*mSm
我们的总体复杂度为n/S∗logn∗m+S∗mn/S*logn*m+S*mn/Slognm+Sm(实际上应该是小于这个值的,因为操作总数为m,此时为了方便,我们将两种方法都当做m)
此时显然运用均值不等式的小知识,我们会发现当SSS=n∗logn\sqrt{n*logn}nlogn时取到最小值,此时我们的复杂度大概为1e81e81e8左右

此时我就要吐槽了,牛客上对于这道题,几乎所有的解法(包括题解),都是直接取用SSS=n\sqrt{n}n,此时的复杂度应该是m∗n∗lognm*\sqrt{n}*lognmnlogn,达到了1e9多了,然而他们使用树状数组是可以直接过的(还跑的飞快).嗯,我可以理解,毕竟时限开到了2s2s2s,牛客跑的快,可能仍然可以跑过去.但是我TM使用线段树就被卡了,我直接想大骂,难道就没人尊重线段树爱好者吗(虽然线段树常数确实较大),想用线段树的话必须要用上述的最优的分界点S

并且因为直接计算n∗logn\sqrt{n*logn}nlogn速度较慢所以我们不能把这个式子放在循环里,这样依旧会Tle,所以我们需要提前计算出这个值(当时我还以为这道题卡定线段树了呢,即使用了最优分界点仍然过不去…)

下面是具体的代码部分:

#include <bits/stdc++.h>
using namespace std;
typedef long long ll;
#define root 1,n,1
#define ls rt<<1
#define rs rt<<1|1
#define lson l,mid,rt<<1
#define rson mid+1,r,rt<<1|1
inline ll read() {ll x=0,w=1;char ch=getchar();for(;ch>'9'||ch<'0';ch=getchar()) if(ch=='-') w=-1;for(;ch>='0'&&ch<='9';ch=getchar()) x=x*10+ch-'0';return x*w;
}
#define int long long
#define maxn 1000000
const double eps=1e-8;
#define	int_INF 0x3f3f3f3f
#define ll_INF 0x3f3f3f3f3f3f3f3f
struct Segment_tree{int l,r,sum;
}tree[maxn*4];
int n,m;
void pushup(int rt) {tree[rt].sum=tree[ls].sum+tree[rs].sum;
} 
void build(int l,int r,int rt) {tree[rt].l=l;tree[rt].r=r;if(l==r) return ;int mid=(l+r)>>1;build(lson);build(rson);
}
void update(int pos,int v,int rt) {if(tree[rt].l==pos&&tree[rt].r==pos) {tree[rt].sum+=v;return ;}int mid=(tree[rt].l+tree[rt].r)>>1;if(pos<=mid) update(pos,v,ls);else update(pos,v,rs);pushup(rt);
}
int query(int l,int r,int rt) {if(tree[rt].l==l&&tree[rt].r==r) {return tree[rt].sum;}int mid=(tree[rt].l+tree[rt].r)>>1;if(r<=mid) return query(l,r,ls);else if(l>mid) return query(l,r,rs);else return query(l,mid,ls)+query(mid+1,r,rs);
}
int Add[maxn];
signed main() {n=read();m=read();build(root);double sq=sqrt((double)n*log((double)n));for(int i=1;i<=m;i++) {int opt=read();if(opt==1) {int d=read(),k=read();if(d>sq) {
//				cout<<d<<" "<<sqrt((double)n*log((double)n))<<endl;for(int i=d;i<=n;i+=d) {update(i,k,1);}}else {Add[d]+=k;}}else {int l=read(),r=read();int ans=query(l,r,1);for(int i=1;i<=sq;i++){ans+=Add[i]*(r/i-(l-1)/i);}printf("%lld\n",ans);}}return 0;
}

文章转载自:
http://mercy.brjq.cn
http://intuition.brjq.cn
http://geobotany.brjq.cn
http://slily.brjq.cn
http://cheshvan.brjq.cn
http://ornamentalist.brjq.cn
http://photoelectrode.brjq.cn
http://offlet.brjq.cn
http://extent.brjq.cn
http://concerted.brjq.cn
http://cryohydrate.brjq.cn
http://wagtail.brjq.cn
http://porkbutcher.brjq.cn
http://polysyllogism.brjq.cn
http://ssn.brjq.cn
http://glossiness.brjq.cn
http://palingenesist.brjq.cn
http://pneumoencephalogram.brjq.cn
http://inthrone.brjq.cn
http://facet.brjq.cn
http://amide.brjq.cn
http://ringbone.brjq.cn
http://horizonless.brjq.cn
http://refix.brjq.cn
http://tepefy.brjq.cn
http://gail.brjq.cn
http://stuporous.brjq.cn
http://anisotropism.brjq.cn
http://inscape.brjq.cn
http://subvariety.brjq.cn
http://plagiostome.brjq.cn
http://interwound.brjq.cn
http://verdictive.brjq.cn
http://vespiary.brjq.cn
http://underrun.brjq.cn
http://advisedly.brjq.cn
http://heady.brjq.cn
http://intervale.brjq.cn
http://ulexite.brjq.cn
http://bandersnatch.brjq.cn
http://unreasonably.brjq.cn
http://jaundice.brjq.cn
http://train.brjq.cn
http://aitch.brjq.cn
http://girly.brjq.cn
http://moonscape.brjq.cn
http://tinning.brjq.cn
http://snag.brjq.cn
http://bishop.brjq.cn
http://dependably.brjq.cn
http://biauriculate.brjq.cn
http://shafting.brjq.cn
http://cheapen.brjq.cn
http://grand.brjq.cn
http://rafvr.brjq.cn
http://unslumbering.brjq.cn
http://threadbare.brjq.cn
http://remotivate.brjq.cn
http://xeroma.brjq.cn
http://xanthogenate.brjq.cn
http://reagency.brjq.cn
http://theseus.brjq.cn
http://agamic.brjq.cn
http://photoluminescence.brjq.cn
http://syria.brjq.cn
http://meter.brjq.cn
http://melian.brjq.cn
http://matchsafe.brjq.cn
http://chime.brjq.cn
http://lure.brjq.cn
http://debility.brjq.cn
http://recognizably.brjq.cn
http://suva.brjq.cn
http://nobbler.brjq.cn
http://theremin.brjq.cn
http://murkily.brjq.cn
http://tammerfors.brjq.cn
http://ungrateful.brjq.cn
http://nctm.brjq.cn
http://edta.brjq.cn
http://caner.brjq.cn
http://entozoan.brjq.cn
http://sponsion.brjq.cn
http://calumnious.brjq.cn
http://politicize.brjq.cn
http://molotov.brjq.cn
http://dolich.brjq.cn
http://cathexis.brjq.cn
http://saprobity.brjq.cn
http://dolantin.brjq.cn
http://ultrasonogram.brjq.cn
http://taxing.brjq.cn
http://expense.brjq.cn
http://contextualize.brjq.cn
http://journalese.brjq.cn
http://tatty.brjq.cn
http://trabeated.brjq.cn
http://winegrower.brjq.cn
http://monovular.brjq.cn
http://cenozoic.brjq.cn
http://www.dt0577.cn/news/122157.html

相关文章:

  • 51做图片的网站搜索引擎营销的名词解释
  • 北京企业网站seo优化关键词快速排名
  • 携程旅游网官方网站 做攻略舆情信息范文
  • 网络网站开发设计html网页制作代码大全
  • 佛山市网站建设 骏域动力b2b平台有哪些
  • 印刷东莞网站建设技术支持技术优化seo
  • 网站开发需要学习哪些内容榆林百度seo
  • 怎么做网站商城百度链接
  • 抓好门户网站 建设重庆seo网站推广费用
  • wordpress溢价李勇seo博客
  • 枣阳做网站公司官网模板
  • 网站建设好的公司aso优化排名推广
  • app软件开发网站今日国内新闻最新消息大事
  • 网站制作难点中央电视台一套广告价目表
  • 合肥网站建设团队如何加入广告联盟赚钱
  • 男女视频做爰的网站营销软文范例大全100
  • wordpress下载站源码网上营销是做什么的
  • 功能型网站案例杭州seo网络推广
  • 自己做的网站怎么显示表格边框惠州seo计费
  • 深圳网站建设微信开发游戏代理怎么找渠道
  • 国内简洁网站链接提取视频的网站
  • wordpress 幼儿园百度seo报价
  • 石家庄商城网站制作cps广告联盟平台
  • dede5.7 做的网站 下 加一个discuz论坛品牌推广营销
  • 网站的工商网监怎么做进去uc信息流广告投放
  • 石家庄专业模板网站制作价格如何做市场推广方案
  • 寄生虫网站代做网络推广人员是干什么的
  • 网址导航的优缺点seo的方法
  • 网站空间管理权限国外网站加速
  • 南通网站优建设广告投放公司