A:显然排序即可。

#include<bits/stdc++.h>
using namespace std;
#define ll long long
#define inf 1000000010
#define N 1010
char getc(){char c=getchar();while ((c<'A'||c>'Z')&&(c<'a'||c>'z')&&(c<'0'||c>'9')) c=getchar();return c;}
int gcd(int n,int m){return m==0?n:gcd(m,n%m);}
int read()
{
int x=0,f=1;char c=getchar();
while (c<'0'||c>'9') {if (c=='-') f=-1;c=getchar();}
while (c>='0'&&c<='9') x=(x<<1)+(x<<3)+(c^48),c=getchar();
return x*f;
}
int n,a[N<<1];
signed main()
{
n=read();
for (int i=1;i<=2*n;i++ )a[i]=read();
sort(a+1,a+2*n+1);int s=0;
for (int i=1;i<=n;i++) s+=a[i];
int s2=0;for (int i=n+1;i<=2*n;i++) s2+=a[i];
if (s!=s2) {for (int i=1;i<=2*n;i++) cout<<a[i]<<' ';}
else cout<<-1;
return 0;
//NOTICE LONG LONG!!!!!
}

  B:若奇偶数均存在就可以任意交换,sort即可。否则无法改变。

#include<bits/stdc++.h>
using namespace std;
#define ll long long
#define inf 1000000010
#define N 100010
char getc(){char c=getchar();while ((c<'A'||c>'Z')&&(c<'a'||c>'z')&&(c<'0'||c>'9')) c=getchar();return c;}
int gcd(int n,int m){return m==0?n:gcd(m,n%m);}
int read()
{
int x=0,f=1;char c=getchar();
while (c<'0'||c>'9') {if (c=='-') f=-1;c=getchar();}
while (c>='0'&&c<='9') x=(x<<1)+(x<<3)+(c^48),c=getchar();
return x*f;
}
int n,a[N];
signed main()
{
n=read();
for (int i=1;i<=n;i++) a[i]=read();
int s=0,s2=0;
for (int i=1;i<=n;i++) if (a[i]&1) s++;else s2++;
if (s&&s2) sort(a+1,a+n+1);
for (int i=1;i<=n;i++) printf("%d ",a[i]);
return 0;
//NOTICE LONG LONG!!!!!
}

  C:质数下标之间需要两两不同,于是最大值就是<=n的质数个数。对于合数,将其设为其最小质因子对应的数即可。

#include<bits/stdc++.h>
using namespace std;
#define ll long long
#define inf 1000000010
#define N 100010
char getc(){char c=getchar();while ((c<'A'||c>'Z')&&(c<'a'||c>'z')&&(c<'0'||c>'9')) c=getchar();return c;}
int gcd(int n,int m){return m==0?n:gcd(m,n%m);}
int read()
{
int x=0,f=1;char c=getchar();
while (c<'0'||c>'9') {if (c=='-') f=-1;c=getchar();}
while (c>='0'&&c<='9') x=(x<<1)+(x<<3)+(c^48),c=getchar();
return x*f;
}
int n,a[N];
bool isprime(int x)
{
for (int i=2;i*i<=x;i++) if (x%i==0) return 0;
return 1;
}
signed main()
{
n=read();
int mx=0;
for (int i=2;i<=n;i++)
if (isprime(i)) a[i]=++mx;
else
{
for (int j=2;j*j<=i;j++) if (i%j==0) {a[i]=a[j];break;}
}
for (int i=2;i<=n;i++) printf("%d ",a[i]);
return 0;
//NOTICE LONG LONG!!!!!
}

  D:如果m>=2n即没有限制,使序列前缀和依次为0,1,2……即可。否则这些数中有一半不能选择,做法类似。

#include<bits/stdc++.h>
using namespace std;
#define ll long long
#define inf 1000000010
#define N 18
char getc(){char c=getchar();while ((c<'A'||c>'Z')&&(c<'a'||c>'z')&&(c<'0'||c>'9')) c=getchar();return c;}
int gcd(int n,int m){return m==0?n:gcd(m,n%m);}
int read()
{
int x=0,f=1;char c=getchar();
while (c<'0'||c>'9') {if (c=='-') f=-1;c=getchar();}
while (c>='0'&&c<='9') x=(x<<1)+(x<<3)+(c^48),c=getchar();
return x*f;
}
int n,m,a[1<<N],cnt;
signed main()
{
n=read(),m=read();
if (m>=(1<<n))
{
cout<<(1<<n)-1<<endl;
for (int i=1;i<(1<<n);i++) printf("%d ",i^(i-1));
}
else
{
for (int i=1;i<(1<<n);i++) if (i<(i^m)) a[++cnt]=i;
cout<<(1<<n-1)-1<<endl;
for (int i=1;i<=(1<<n-1)-1;i++) printf("%d ",a[i]^a[i-1]);
}
return 0;
//NOTICE LONG LONG!!!!!
}

  E:容易发现前缀gcd最大变化次数就是<=n的数所拥有的最大质因子个数。显然形如2k的数满足条件。同时3*2k-1也可能满足条件。对于前者, 设c[i]=[n/2i]-[n/2i+1],也即恰有i个2的数的个数,那么合法排列方案数的计算类似于CTS2019随机立方体https://www.cnblogs.com/Gloid/p/10936699.html中的一个子问题,不再赘述。后者的话考虑一下3这个因子在还剩多少个2时被删去,类似地计算。

#include<bits/stdc++.h>
using namespace std;
#define ll long long
#define inf 1000000010
#define N 1000010
#define P 1000000007
char getc(){char c=getchar();while ((c<'A'||c>'Z')&&(c<'a'||c>'z')&&(c<'0'||c>'9')) c=getchar();return c;}
int gcd(int n,int m){return m==0?n:gcd(m,n%m);}
int read()
{
int x=0,f=1;char c=getchar();
while (c<'0'||c>'9') {if (c=='-') f=-1;c=getchar();}
while (c>='0'&&c<='9') x=(x<<1)+(x<<3)+(c^48),c=getchar();
return x*f;
}
int n,ans,a[30],fac[N],inv[N],b[2][30];
int C(int n,int m){if (m>n) return 0;return 1ll*fac[n]*inv[m]%P*inv[n-m]%P;}
void inc(int &x,int y){x+=y;if (x>=P) x-=P;}
signed main()
{
n=read();
fac[0]=1;for (int i=1;i<=n;i++) fac[i]=1ll*fac[i-1]*i%P;
inv[0]=inv[1]=1;for (int i=2;i<=n;i++) inv[i]=P-1ll*(P/i)*inv[P%i]%P;
for (int i=2;i<=n;i++) inv[i]=1ll*inv[i]*inv[i-1]%P;
int m=0,tmp=n;while (tmp) m++,tmp>>=1;
m--;
if ((3<<m-1)<=n)
{
for (int i=1;i<=n;i++)
{
int x=0,y=i;
while (y%2==0) y>>=1,x++;
if (i%3==0) b[1][min(x,m-1)]++;
else b[0][min(x,m-1)]++;
}
for (int i=m-1;i>=0;i--)
{
int s=1,u=n;
for (int j=m-1;j>=i;j--)
{
s=1ll*s*C(u-1,b[1][j]-1)%P*fac[b[1][j]]%P;
u-=b[1][j];
}
int tot=0;for (int j=m-1;j>=i;j--) tot+=b[0][j];
s=1ll*s*C(u-1,tot-1)%P*fac[tot]%P;
u-=tot;
for (int j=i-1;j>=0;j--)
{
s=1ll*s*C(u-1,b[0][j]+b[1][j]-1)%P*fac[b[0][j]+b[1][j]]%P;
u-=b[0][j]+b[1][j];
}
inc(ans,s);
}
}
memset(a,0,sizeof(a));
for (int i=1;i<=n;i++)
{
int x=0,y=i;
while (y%2==0) y>>=1,x++;
a[x]++;
}
int s=1,u=n;
for (int i=m;i>=0;i--)
{
s=1ll*s*C(u-1,a[i]-1)%P*fac[a[i]]%P;
u-=a[i];
}
inc(ans,s);
cout<<ans;
return 0;
//NOTICE LONG LONG!!!!!
}

  F:点分治,问出当前点深度就可以知道其是不是隐藏点的祖先。如果不是就在该点父亲所在子树中继续寻找,否则问出到隐藏点路径上的第二个点到对应子树中寻找。发现离隐藏点距离为0时就找到了。

#include<bits/stdc++.h>
using namespace std;
#define ll long long
#define N 200010
char getc(){char c=getchar();while ((c<'A'||c>'Z')&&(c<'a'||c>'z')&&(c<'0'||c>'9')) c=getchar();return c;}
int gcd(int n,int m){return m==0?n:gcd(m,n%m);}
int read()
{
int x=0,f=1;char c=getchar();
while (c<'0'||c>'9') {if (c=='-') f=-1;c=getchar();}
while (c>='0'&&c<='9') x=(x<<1)+(x<<3)+(c^48),c=getchar();
return x*f;
}
int n,p[N],t,d,fa[N],deep[N],size[N];
bool flag[N];
struct data{int to,nxt;
}edge[N<<1];
void addedge(int x,int y){t++;edge[t].to=y,edge[t].nxt=p[x],p[x]=t;}
void dfs(int k)
{
for (int i=p[k];i;i=edge[i].nxt)
if (edge[i].to!=fa[k])
{
deep[edge[i].to]=deep[k]+1;
fa[edge[i].to]=k;
dfs(edge[i].to);
}
}
void make(int k,int from)
{
size[k]=1;
for (int i=p[k];i;i=edge[i].nxt)
if (edge[i].to!=from&&!flag[edge[i].to])
{
make(edge[i].to,k);
size[k]+=size[edge[i].to];
}
}
int findroot(int k,int from,int s)
{
int mx=0;
for (int i=p[k];i;i=edge[i].nxt)
if (edge[i].to!=from&&!flag[edge[i].to]&&size[edge[i].to]>size[mx]) mx=edge[i].to;
if ((size[mx]<<1)>s) return findroot(mx,k,s);
else return k;
}
int getd(int x){cout<<"d "<<x<<endl;return read();}
int gets(int x){cout<<"s "<<x<<endl;return read();}
int solve(int k)
{
make(k,k);flag[k=findroot(k,k,size[k])]=1;
int u=getd(k);if (u==0) return k;
if (deep[k]+u==d) return solve(gets(k));
else return solve(fa[k]);
}
int main()
{
n=read();
for (int i=1;i<n;i++)
{
int x=read(),y=read();
addedge(x,y),addedge(y,x);
}
dfs(1);
d=getd(1);
cout<<"! "<<solve(1);
return 0;
}

  小小小号。result:rank 18 rating +163

Codeforces Round #563 Div. 2的更多相关文章

  1. Codeforces Round #563 (Div. 2)/CF1174

    Codeforces Round #563 (Div. 2)/CF1174 CF1174A Ehab Fails to Be Thanos 其实就是要\(\sum\limits_{i=1}^n a_i ...

  2. Codeforces Round #563 (Div. 2) C. Ehab and a Special Coloring Problem

    链接:https://codeforces.com/contest/1174/problem/C 题意: You're given an integer nn. For every integer i ...

  3. Codeforces Round #563 (Div. 2) B. Ehab Is an Odd Person

    链接:https://codeforces.com/contest/1174/problem/B 题意: You're given an array aa of length nn. You can ...

  4. Codeforces Round #563 (Div. 2) A. Ehab Fails to Be Thanos

    链接:https://codeforces.com/contest/1174/problem/A 题意: You're given an array aa of length 2n2n. Is it ...

  5. Codeforces Round #563 (Div. 2)C

    C. Ehab and a Special Coloring Problem 题目链接:http://codeforces.com/contest/1174/problem/C 题目 You're g ...

  6. Codeforces Round #563 (Div. 2)B

    B.Ehab Is an Odd Person 题目链接:http://codeforces.com/contest/1174/problem/B 题目 You’re given an array a ...

  7. Codeforces Round #563 (Div. 2)A

    A. Ehab Fails to Be Thanos 题目链接:http://codeforces.com/contest/1174/problem/A 题目 You’re given an arra ...

  8. Codeforces Round #563 (Div. 2) E. Ehab and the Expected GCD Problem

    https://codeforces.com/contest/1174/problem/E dp 好题 *(if 满足条件) 满足条件 *1 不满足条件 *0 ///这代码虽然写着方便,但是常数有点大 ...

  9. Codeforces Round #563 (Div. 2) F. Ehab and the Big Finale

    后续: 点分治标程 使用father数组 比使用vis数组优秀(不需要对vis初始化) https://codeforces.com/problemset/problem/1174/F https:/ ...

  10. Codeforces Round 563 (Div. 2) 题解

    自己开了场镜像玩. 前三题大水题.D有点意思.E完全不会.F被题意杀了……然而还是不会. 不过看过(且看懂)了官方题解,所以这里是六题题解齐全的. A 水题.给原序列排序,如果此时合法则直接输出,否则 ...

随机推荐

  1. 新概念英语第二册Lesson5:No wrong numbers

    Lesson 5 No wrong numbers 无错号之虞 First listen and then answer the question. 听录音,然后回答以下问题. What does ' ...

  2. Quartz Configuration Reference

    Quartz Configuration Reference Choose a topic: Main Configuration (configuration of primary schedule ...

  3. Linux expect的安装与使用

    Expect是在Tcl的基础上创建的,可以用来做一些Linux下无法做到交互的命令操作,可用于远程管理服务器. 一.安装Tcl: 1.下载源码包: wget http://nchc.dl.source ...

  4. 【插件式框架探索系列】应用程序域(AppDomain)

    应用程序域(AppDomain)已经不是一个新名词了,只要熟悉.net的都知道它的存在,不过我们还是先一起来重新认识下应用程序域吧,究竟它是何方神圣. 应用程序域 众所周知,进程是代码执行和资源分配的 ...

  5. 【Spring】基于@Aspect的AOP配置

    Spring AOP面向切面编程,可以用来配置事务.做日志.权限验证.在用户请求时做一些处理等等.用@Aspect做一个切面,就可以直接实现. ·   本例演示一个基于@Aspect的小demo 1. ...

  6. Sq常用操作

    sql创建表实例: CREATE TABLE mytable( id varchar(40) NOT NULL default '', userId varchar(40) NOT NULL defa ...

  7. 【helm & Tiller】报错Error: incompatible versions client[v2.14.1] server[v2.13.0] │

    helm是helm的客户端部分 tiller是helm的服务器端部分 报错 报错Error: incompatible versions client[v2.14.1] server[v2.13.0] ...

  8. python解析本地HTML文件

    Python使用爬虫技术时,每运行一次,本地都会访问一次主机.为避免完成程序前调试时多次访问主机增加主机负荷,我们可以在编写程序前将网页源代码存在本地,调试时访问本地文件即可.现在我来分享一下爬取资料 ...

  9. 【网络开发】UDP组播接收端解析

    UDP组播接收端解析 网络中的一台主机如果希望能够接收到来自网络中其它主机发往某一个组播组的数据报,那么这么主机必须先加入该组播组,然后就可以从组地址接收数据包.在广域网中,还涉及到路由器支持组播路由 ...

  10. 高级UI-SVG

    栅格图可以实现图片的清晰显示,但这也意味着如果要在各种设备上使用栅格图,那么在使用的时候就会产生为了适配各种尺寸的设备而增加大量不同规格的栅格图,这也直接导致了资源文件体积的增大,矢量图就不存在这个问 ...