传送门

今天子帧的一套模拟题的T3。

考试的时候其实已经想到了正解了,但是一些地方没有想清楚,就没敢写,只打了个暴力。

首先考虑用线段树维护区间信息。

先把每个值拆成两个信息,一是距离他最近的且大于他的$42$的整次幂,而是到距离他最近的且大于他的$42$的整次幂的距离。

操作1和操作2不需要细说。

对于操作3,每次加入一个数后check整棵线段树的Min,如果出现负数就逐个升级。如果出现了0就再次增加,直到不出现0为止。

因为每个数最多升级$logN$次,所以时间上是没有问题的。

另一个小细节(被卡了很长时间),在每次下传操作2的lazytag之前要先将下一个的操作3的lazytag清空。

//Codeforces 679E
//by Cydiater
//2017.1.20
#include <iostream>
#include <queue>
#include <map>
#include <ctime>
#include <cstring>
#include <string>
#include <cmath>
#include <ctime>
#include <iomanip>
#include <cstdlib>
#include <cstdio>
#include <bitset>
#include <set>
#include <vector>
using namespace std;
#define ll long long
#define up(i,j,n)	for(int i=j;i<=n;i++)
#define down(i,j,n)	for(int i=j;i>=n;i--)
#define cmax(a,b)	a=max(a,b)
#define cmin(a,b)	a=min(a,b)
#define FILE		"bad42"
const int MAXN=2e5+5;
inline int read(){
	char ch=getchar();int x=0,f=1;
	while(ch>'9'||ch<'0'){if(ch=='-')f=-1;ch=getchar();}
	while(ch>='0'&&ch<='9'){x=x*10+ch-'0';ch=getchar();}
	return x*f;
}
ll pw[MAXN],N,M,arr[MAXN];
//little tool
ll Level(ll num){up(i,0,11)if(pw[i]>=num)return i;}
ll Dist(ll num){up(i,0,11)if(pw[i]>=num)return pw[i]-num;}
struct tree{
	ll Min,tag1,tag2,level;
	//tag1 -> opt2
	//tag2 -> opt3
}t[MAXN<<2];
namespace SegmentTree{
	inline void reload(int root){t[root].Min=min(t[root<<1].Min,t[root<<1|1].Min);}
	inline void Uplevel(int root){
		ll num=pw[t[root].level]-t[root].Min;
		t[root].level=Level(num);
		t[root].Min=Dist(num);
	}
	inline void Pushdown(int leftt,int rightt,int root){
		if(t[root].tag1>0){
			if(leftt!=rightt){
				t[root<<1].level=Level(t[root].tag1);
				t[root<<1].Min=Dist(t[root].tag1);
				t[root<<1].tag1=t[root].tag1;
				t[root<<1].tag2=0;

				t[root<<1|1].level=Level(t[root].tag1);
				t[root<<1|1].Min=Dist(t[root].tag1);
				t[root<<1|1].tag1=t[root].tag1;
				t[root<<1|1].tag2=0;
			}
			t[root].tag1=0;
		}
		if(t[root].tag2>0){
			if(leftt!=rightt){
				t[root<<1].Min-=t[root].tag2;
				t[root<<1].tag2+=t[root].tag2;

				t[root<<1|1].Min-=t[root].tag2;
				t[root<<1|1].tag2+=t[root].tag2;
			}
			t[root].tag2=0;
		}
	}
	void Build(int leftt,int rightt,int root){
		if(leftt==rightt){
			t[root].Min=Dist(arr[leftt]);t[root].level=Level(arr[leftt]);
			t[root].tag1=-1;t[root].tag2=0;
			return;
		}
		int mid=(leftt+rightt)>>1;
		t[root].tag1=-1;t[root].tag2=0;
		Build(leftt,mid,root<<1);
		Build(mid+1,rightt,root<<1|1);
		reload(root);
	}
	ll Realnum(int leftt,int rightt,int root,int pos){
		Pushdown(leftt,rightt,root);
		if(leftt==rightt||t[root].tag1==0)	return pw[t[root].level]-t[root].Min;
		int mid=(leftt+rightt)>>1;
		if(mid>=pos)				return Realnum(leftt,mid,root<<1,pos);
		else if(mid+1<=pos)			return Realnum(mid+1,rightt,root<<1|1,pos);
	}
	void Modify(int leftt,int rightt,int root,int L,int R,int val,int tag){
		Pushdown(leftt,rightt,root);
		int mid=(leftt+rightt)>>1;
		if(leftt>=L&&rightt<=R){
			if(tag==1){
				t[root].tag1=val;
				t[root].level=Level(val);
				t[root].Min=Dist(val);
			}
			else{
				t[root].tag2=val;
				t[root].Min-=val;
			}
			return;
		}
		t[root].tag1=-1;
		if(L>=mid+1)	Modify(mid+1,rightt,root<<1|1,L,R,val,tag);
		else if(R<=mid)	Modify(leftt,mid,root<<1,L,R,val,tag);
		else{
			Modify(leftt,mid,root<<1,L,R,val,tag);
			Modify(mid+1,rightt,root<<1|1,L,R,val,tag);
		}
		reload(root);
	}
	void fix(int leftt,int rightt,int root){
		Pushdown(leftt,rightt,root);
		if(leftt==rightt||t[root].tag1==0){
			Uplevel(root);
			return;
		}
		int mid=(leftt+rightt)>>1;
		if(t[root<<1].Min<0)	fix(leftt,mid,root<<1);
		if(t[root<<1|1].Min<0)	fix(mid+1,rightt,root<<1|1);
		reload(root);
	}
}using namespace SegmentTree;
namespace solution{
	void Prepare(){
		pw[0]=1;
		up(i,1,11)pw[i]=pw[i-1]*42LL;
		N=read();M=read();
		up(i,1,N)arr[i]=read();
		Build(1,N,1);
	}
	void Solve(){
		while(M--){
			int opt=read();
			if(opt==1){
				int pos=read();
				printf("%I64d\n",Realnum(1,N,1,pos));
			}
			if(opt==2){
				int L=read(),R=read(),val=read();
				Modify(1,N,1,L,R,val,1);
			}
			if(opt==3){
				int L=read(),R=read(),val=read();
				do{
					Modify(1,N,1,L,R,val,2);
					//printf("%d\n",Realnum(1,N,1,1));
					if(t[1].Min<0)fix(1,N,1);
				}while(t[1].Min==0);
			}
			//up(i,1,N)printf("%d ",Realnum(1,N,1,i));puts("");
		}
	}
}
int main(){
	//freopen("input.in","r",stdin);
	//freopen("out1.out","w",stdout);
	//freopen(FILE".in","r",stdin);
	//freopen(FILE".out","w",stdout);
	using namespace solution;
	Prepare();
	Solve();
	return 0;
}

Codeforces679E. Bear and Bad Powers of 42的更多相关文章

  1. CF679E Bear and Bad Powers of 42

    一段时间不写线段树标记,有些生疏了 codeforces 679e Bear and Bad Powers of 42 - CHADLZX - 博客园 关键点是:42的次幂,在long long范围内 ...

  2. codeforces 679e Bear and Bad Powers of 42

    传送门:http://codeforces.com/contest/679/problem/E 题目意思很清晰,给你一个序列,要求你完成以下三个操作: 1.输出A[i] 2.将[a,b]区间的所有数字 ...

  3. Lucky Array Codeforces - 121E && Bear and Bad Powers of 42 Codeforces - 679E

    http://codeforces.com/contest/121/problem/E 话说这题貌似暴力可A啊... 正解是想出来了,结果重构代码,调了不知道多久才A 错误记录: 1.线段树搞混num ...

  4. Codeforces 679E - Bear and Bad Powers of 42(线段树+势能分析)

    Codeforces 题目传送门 & 洛谷题目传送门 这个 \(42\) 的条件非常奇怪,不过注意到本题 \(a_i\) 范围的最大值为 \(10^{14}\),而在值域范围内 \(42\) ...

  5. (Problem 29)Distinct powers

    Consider all integer combinations ofabfor 2a5 and 2b5: 22=4, 23=8, 24=16, 25=32 32=9, 33=27, 34=81, ...

  6. Codeforces Round #356 (Div. 2) D. Bear and Tower of Cubes dfs

    D. Bear and Tower of Cubes 题目连接: http://www.codeforces.com/contest/680/problem/D Description Limak i ...

  7. codeforces 680D D. Bear and Tower of Cubes(dfs+贪心)

    题目链接: D. Bear and Tower of Cubes time limit per test 2 seconds memory limit per test 256 megabytes i ...

  8. 【19.05%】【codeforces 680D】Bear and Tower of Cubes

    time limit per test2 seconds memory limit per test256 megabytes inputstandard input outputstandard o ...

  9. 1142 - Summing up Powers (II)

    1142 - Summing up Powers (II)    PDF (English) Statistics Forum Time Limit: 2 second(s) Memory Limit ...

随机推荐

  1. 【BZOJ3416】Poi2013 Take-out 栈

    [BZOJ3416]Poi2013 Take-out Description 小F喜欢玩一个消除游戏——take-out 保证k+1|n,保证输入数据有解这是一个单人游戏 游戏者的目标是消除初始时给定 ...

  2. ios UITableView多选删除

    第一步, - (UITableViewCellEditingStyle)tableView:(UITableView *)tableView editingStyleForRowAtIndexPath ...

  3. Java之Tomcat、Dynamic web project与Servlet

    一.Tomcat配置 Conf   Config   configration   -->配置 Service.xml:用来配置Tomcat Tomcat_users.xml:用来配置Tomca ...

  4. 使用ganymed工具调用ssh2

    需要引入ganymed-ssh2-build210.jar包. 其实很简单.所以直接贴代码,代码说话. package com.eshore.framework.util; import java.i ...

  5. 清除webkit浏览器css设置滚动条

    主要有下面7个属性 ::-webkit-scrollbar 滚动条整体部分,可以设置宽度啥的 ::-webkit-scrollbar-button 滚动条两端的按钮 ::-webkit-scrollb ...

  6. php 乘除法原理

    w $wdays = ceil(($wmaxutime-$wminutime)/(24*3600)); $wdays = ceil(($wmaxutime-$wminutime)/243600); 二 ...

  7. bash characters

    linux shell通配符(wildcard) 通配符是由shell处理的(不是由所涉及到命令语句处理的,其实我们在shell各个命令中也没有发现有这些通配符介绍), 它只会出现在 命令的“参数”里 ...

  8. Cyclic Nacklace ---hdu3746(循环节,kmp)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=3746 给你一个字符串,让你在后面加尽量少的字符,使得这个字符串成为一个重复串. abca---添加bc ...

  9. Python的15个坑

    1. 不要使用可变对象作为函数默认值 代码如下: In [1]: def append_to_list(value, def_list=[]):    ...:         def_list.ap ...

  10. MySQL中的表级锁

    数据的锁主要用来保证数据的一致性,数据库的锁从锁定的粒度上可以分为表级锁,行级锁和页级锁. MySQL的锁机制比较简单,其最显著的特点是不同的存储引擎支持不同的锁机制,比如MyISAM和MEMORY存 ...