签到题这里久懒得写了。

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. 字符集(编码)转换_Linux

    ZC: 来自 我的项目 czgj 1.代码: #include <stdio.h> #include <iconv.h> #include <string.h> / ...

  2. string 和 wstring

    区别: char* wchar_t 一个字节 两个字节 ACSII编码 unicode编码 转换: 1.Windows API WideCharToMultiByte() MultiByteToWid ...

  3. lambda表达式/对象引用计数

    ★lambda表达式的用法例:I=[(lambda x: x*2),(lambda y: y*3)]调用:for x in I: print x(2)输出:4,6 ★获取对象的引用次数sys.getr ...

  4. Unity生成屏幕快照

    public static Texture2D CaptureCamera(Camera camera, Rect rect) { RenderTexture rt = ); RenderTextur ...

  5. Gluttony CodeForces - 892D (构造,思维)

    题面: You are given an array a with n distinct integers. Construct an array b by permuting a such that ...

  6. 『cs231n』神经网络组件

  7. FNDLOAD移植Lookup Type

    通过OAF WEB页面添加的lookup type不能使用fndload直接移植,移植之后无法包含code值,必须使用FORM窗口定义.

  8. OAF点击事件对页面组件的Required属性不验证

    在实际的需求中,OAF页面上很多字段设置了Required=YES,但是我们在点击某些按钮的时候,并不希望浏览器对其进行验证,可以通过设置 Disable Server Side Validation ...

  9. en_e out1

      1◆e i: ə ɜː e i   2◆ eu 3◆ ew 4◆ ei ey eu ew 5◆ eer ue   6◆ ee u: u   7◆ er ɜː     8◆ ere ie ue   ...

  10. hadoop mongodb install(3)

    reference:http://dblab.xmu.edu.cn/blog/868-2/ root@iZuf68496ttdogcxs22w6sZ:~# mv mongodb-linux-x86_6 ...