签到题这里久懒得写了。

B - 缺失的数据范围

Total Submission(s): 2602    Accepted Submission(s): 559

题意:求最大的N,满足N^a*[log2(N)]^b<=K;

思路:二分即可,log2要手写,然后就是注意判pow是否超过long long。

#include<bits/stdc++.h>
#define ll long long
using namespace std;
const int maxn=;
const ll inf=1e18;
ll A,B,K,ans,aa[];
ll Log(ll x){
int pos=lower_bound(aa+,aa++,x)-aa;
return pos;
}
bool check(ll x){
ll a=,res=;
ll b=Log(x);// cout<<b<<" "<<aa[b]<<" ";
for(int i=;i<=A;i++){
if(a>K/x) return false;
a=a*x; if(a>K) return false;
}
for(int i=;i<=B;i++){
if(res>K/b) return false;
res=res*b; if(res>K) return false;
}
//cout<<a<<" "<<b<<endl;
if(a>K/res) return false;
if(a*res<=K) return true;
}
int main()
{
int T;
aa[]=;
for(int i=;i<=;i++) aa[i]=aa[i-]*;
scanf("%d",&T);
while(T--){
scanf("%lld%lld%lld",&A,&B,&K); ans=;
ll L=,R=K;
while(L<=R){
ll Mid=(L+R)/;
if(check(Mid)) ans=Mid,L=Mid+;
else R=Mid-;
}
printf("%lld\n",ans);
}
return ;
}

E - 对称数

Total Submission(s): 469    Accepted Submission(s): 88

题意:给出一棵带点权的树,Q次询问,每次询问给出(u,v),求这个路径上最小的出现次数位偶数的正整数。

思路:树上莫队:皇室联邦法分块,括号法移动区间。

皇室联邦法分块:即按照DFS虚分块。

括号法:dfs时,记录第一次访问时间戳in[]和最后一次访问时间戳out[]。如果访问路径(u,v),保证in[u]<in[v]起对应的区间就是:

1,LCA==u,对应[in[u],in[v]];

2,LCA!=u,对应[out[u],in[v]]+LCA;LCA单独考虑为pre,不要忽略。

#include<bits/stdc++.h>
#define rep(i,a,b) for(int i=a;i<=b;i++)
using namespace std;
const int maxn=;
int a[maxn],Laxt[maxn],Next[maxn],To[maxn],cnt,B;
int g[maxn],dep[maxn],fa[maxn][],ans[maxn],scc,tot;
int in[maxn],out[maxn],p[maxn];
bitset<maxn>Set;
struct in{
int u,v,id;
friend bool operator <(in ww,in vv){
if(g[ww.u]==g[vv.u]) return g[ww.v]<g[vv.v];
return g[ww.u]<g[vv.u];
}
}s[maxn];
void add(int u,int v)
{
Next[++cnt]=Laxt[u]; Laxt[u]=cnt; To[cnt]=v;
}
void dfs(int u,int f)
{
fa[u][]=f; dep[u]=dep[f]+;
if(tot%B==) scc++; g[u]=scc;
in[u]=++tot; p[tot]=a[u];
for(int i=Laxt[u];i;i=Next[i]){
if(To[i]!=f) dfs(To[i],u);
}
out[u]=++tot; p[tot]=a[u];
}
int LCA(int u,int v)
{
if(dep[u]<dep[v]) swap(u,v);
for(int i=;i>=;i--)
if(dep[fa[u][i]]>=dep[v]) u=fa[u][i];
if(u==v) return u;
for(int i=;i>=;i--)
if(fa[u][i]!=fa[v][i]) u=fa[u][i],v=fa[v][i];
return fa[u][];
}
int main()
{
int T,N,M,u,v,Lca;
scanf("%d",&T);
while(T--){
scanf("%d%d",&N,&M); B=sqrt(N);
cnt=; rep(i,,N) Laxt[i]=;
rep(i,,N) scanf("%d",&a[i]);
rep(i,,N-){
scanf("%d%d",&u,&v);
add(u,v); add(v,u);
}
tot=; scc=; dfs(,);
rep(i,,) rep(j,,N) fa[j][i]=fa[fa[j][i-]][i-];
rep(i,,M) scanf("%d%d",&s[i].u,&s[i].v),s[i].id=i;
rep(i,,M) if(in[s[i].u]>in[s[i].v]) swap(s[i].u,s[i].v);
sort(s+,s+M+);
Set.set();
int L=,R=,pre=; Set.flip(p[]);
rep(i,,M) {
Set.flip(pre);
int Lca=LCA(s[i].u,s[i].v),l,r;
if(Lca==s[i].u) l=in[s[i].u],r=in[s[i].v],pre=;
else l=out[s[i].u],r=in[s[i].v],Set.flip(a[Lca]),pre=a[Lca];
while(l<L) Set.flip(p[--L]);
while(l>L) Set.flip(p[L++]);
while(r>R) Set.flip(p[++R]);
while(r<R) Set.flip(p[R--]);
int pos=Set._Find_next();
ans[s[i].id]=pos;
}
rep(i,,M) printf("%d\n",ans[i]);
}
return ;
}

I - 回文树

题意:给出一棵带权树,点权随机给出,求树上有多少回文串。

思路:由于是随机,我们大胆猜测,只存在长度为1,2和3的回文串。

Total Submission(s): 198    Accepted Submission(s): 45

#include<bits/stdc++.h>
#define rep(i,a,b) for(int i=a;i<=b;i++)
using namespace std;
const int maxn=;
int a[maxn]; map<int,int>mp[maxn];
int main()
{
int N,T,u,v;
scanf("%d",&T);
while(T--){
int ans=;
scanf("%d",&N);
rep(i,,N) mp[i].clear();
rep(i,,N) scanf("%d",&a[i]);
rep(i,,N-){
scanf("%d%d",&u,&v);
if(a[u]==a[v]) ans++;
ans+=mp[u][a[v]];
ans+=mp[v][a[u]];
mp[u][a[v]]++; mp[v][a[u]]++;
}
printf("%d\n",ans+N);
}
return ;
}

2018CCPC女生赛(树上莫队)的更多相关文章

  1. 【BZOJ 3735】苹果树 树上莫队(树分块+离线莫队+鬼畜的压行)

    2016-05-09 UPD:学习了新的DFS序列分块,然后发现这个东西是战术核导弹?反正比下面的树分块不知道要快到哪里去了 #include<cmath> #include<cst ...

  2. 【BZOJ-3757】苹果树 块状树 + 树上莫队

    3757: 苹果树 Time Limit: 20 Sec  Memory Limit: 256 MBSubmit: 1305  Solved: 503[Submit][Status][Discuss] ...

  3. [BZOJ 3052] [wc2013] 糖果公园 【树上莫队】

    题目链接:BZOJ - 3052 题目分析 这道题就是非常经典的树上莫队了,并且是带修改的莫队. 带修改的莫队:将询问按照 左端点所在的块编号为第一关键字,右端点所在的块为第二关键字,位于第几次修改之 ...

  4. 树上莫队 wowow

    构建:像线性的莫队那样,依旧是按sqrt(n)为一块分块. int dfs(int x){ ; dfn[x]=++ind; ;i<=;i++) if (bin[i]<=deep[x]) f ...

  5. spoj COT2 - Count on a tree II 树上莫队

    题目链接 http://codeforces.com/blog/entry/43230树上莫队从这里学的,  受益匪浅.. #include <iostream> #include < ...

  6. BZOJ 4129: Haruna’s Breakfast [树上莫队 分块]

    传送门 题意: 单点修改,求一条链的mex 分块维护权值,$O(1)$修改$O(S)$求mex...... 带修改树上莫队 #include <iostream> #include < ...

  7. 【WC2013】糖果公园 [树上莫队]

    题意: 一棵树,修改一个点的颜色,询问两点路径上每种颜色的权值$val[c]$*出现次数的权值$cou[w[c]]$的和 sro VFK 树上莫队 按照王室联邦的方法分块,块的大小直径个数有保证,并不 ...

  8. Codeforces 852I Dating 树上莫队

    Dating 随便树上莫队搞一搞就好啦. #include<bits/stdc++.h> #define LL long long #define LD long double #defi ...

  9. 【XSY1642】Another Boring Problem 树上莫队

    题目大意 给你一棵\(n\)个点的树,每个点有一个颜色\(c_i\),每次给你\(x,y,k\),求从\(x\)到\(y\)的路径上出现次数第\(k\)多的颜色的出现次数 \(n,q\leq 1000 ...

随机推荐

  1. Codeforces 294D - Shaass and Painter Robot

    294D - Shaass and Painter Robot 思路: 可以用数学归纳法证明一个结论:整个棋盘黑白相间当且仅当边缘黑白相间. 分奇偶讨论又可得出边缘黑色格个数为n+m-2 这样就可以暴 ...

  2. CAS-自旋锁

    自旋锁 自旋锁(spinlock):是指当一个线程在获取锁的时候,如果锁已经被其它线程获取,那么该线程将循环等待,然后不断的判断锁是否能够被成功获取,直到获取到锁才会退出循环.  获取锁的线程一直处于 ...

  3. 一个Java例子,解释清楚注解的作用

    原文出处:码农登陆 写在前面 今天聊的是注解,但其实单纯说注解,注解本身没有任何的作用.简单说和注释没啥区别,而它有作用的原因是:注解解释类,也就是相关对代码进行解释的特定类.一般这些类使用反射是可以 ...

  4. WPF StoryBoard用法

    时间:2011-06-15 21:26来源:百度空间 作者:shichen4 点击: 次 StoryBoard使用,Xaml转cs代码 Canvas.Triggers EventTriggerRout ...

  5. hpu1165 贪心

    1165: 最少的需求 [贪心] 时间限制: 1 Sec 内存限制: 128 MB 提交: 12 解决: 4 状态 题目描述 小Q开了一家餐厅,最近生意非常火爆. 假设有N N 个预订信息,第i i ...

  6. 10046 event 知多少

    10046 event 知多少 2017年5月10日 10:08 1.在当前session级打开trace 适用于SQL语句可以在新的session创建后再运行. 在session级收集10046 t ...

  7. Eureka服务注册过程详解之IpAddress(详解eureka.instance.prefer-ip-address = true 与 eureka.instance.prefer-ip-address)

    分析,eureka.instance.prefer-ip-address 本节解释为什么配置eureka.instance.prefer-ip-address = true时,注册到Eureka Se ...

  8. ECC算法整理纪要

    初始ECC算法 1.用户A 密钥生成 (1):用随机数发生器产生随机数k∈[1,n-1]: (2):计算椭圆曲线点PA=[k]G,为公钥,k为用户A私钥: 2. 用户B加密算法及流程 设需要发送的消息 ...

  9. react中为什么要使用immutable

    因为在react中,react的生命周期中的setState()之后的shouldComponentUpdate()阶段默认返回true,所以会造成本组件和子组件的多余的render,重新生成virt ...

  10. 超级好用的C++万能头文件

    #include<bits/stdc++.h>包含了目前c++所包含的所有头文件 对比: #include <iostream> #include <cstdio> ...