AtCoder Beginner Contest 220
A、B、C、D、F比较简单,没必要写出来
E - Distance on Large Perfect Binary Tree
题目
问一个深度为 \(n\)的满二叉树有多少个点对的距离恰好为 \(D\)
\(n\leq 10^6,D\leq 2*10^6\)
分析
其实此题也比较简单但是赛时没调出来QAQ
考虑分成两种情况讨论,一种情况是其中一个为 \(LCA\),
那么这个就是\(\sum_{i=1}^n2^{i-1}*2^D[i+D\leq n]\)
另一种就枚举其中一个点往下的度数,也就是
\]
也就是
\]
代码
#include <cstdio>
#define rr register
using namespace std;
const int mod=998244353;
int two[2000011],ans,n,m;
inline signed max(int a,int b){return a>b?a:b;}
inline signed min(int a,int b){return a<b?a:b;}
signed main(){
scanf("%d%d",&n,&m),two[0]=1;
for (rr int i=1;i<=n*2;++i) two[i]=2ll*two[i-1]%mod;
for (rr int i=1;i<=n;++i){
rr int l=max(1,i+m-n),r=min(m-1,n-i);
if (l<=r) ans=(ans+1ll*(r-l+1)*two[i-1]%mod*two[m-1]%mod)%mod;
}
for (rr int i=m+1;i<=n;++i) ans=(ans+two[i])%mod;
return !printf("%d",ans);
}
G - Isosceles Trapezium
题目
给定 \(n\) 个点,点权为 \(w_i\),
问其中四个点构成的等腰梯形的最大点权和
分析
等腰梯形的上底和下底中点的连线垂直于上底和下底,用这个性质枚举线段即可
代码
#include <cstdio>
#include <cctype>
#include <map>
#include <algorithm>
#define rr register
using namespace std;
const int N=1011; typedef long long lll;
map<pair<double,double>,int>uk; lll ans=-4e9;
map<pair<lll,lll>,lll>K[N*N]; int n,lA,lB,cnt;
map<pair<lll,lll>,lll>::iterator it;
struct Point{lll x,y,w;}a[N],A[N*N],B[N*N];
inline signed iut(){
rr int ans=0,f=1; rr char c=getchar();
while (!isdigit(c)) f=(c=='-')?-f:f,c=getchar();
while (isdigit(c)) ans=(ans<<3)+(ans<<1)+(c^48),c=getchar();
return ans*f;
}
inline lll max(lll a,lll b){return a>b?a:b;}
bool cmpx(Point x,Point y){return x.x<y.x||(x.x==y.x&&x.y<y.y);}
bool cmpy(Point x,Point y){return x.y<y.y||(x.y==y.y&&x.x<y.x);}
signed main(){
n=iut();
for (rr int i=1;i<=n;++i)
a[i]=(Point){iut(),iut(),iut()};
for (rr int i=1;i<n;++i)
for (rr int j=i+1;j<=n;++j){
rr Point t=(Point){a[i].x+a[j].x,a[i].y+a[j].y,a[i].w+a[j].w};
if (a[i].x==a[j].x) A[++lA]=t;
else if (a[i].y==a[j].y) B[++lB]=t;
else {
rr double k=(double)(a[j].x-a[i].x)/(a[i].y-a[j].y),b=t.y-k*t.x;
if (!uk[make_pair(k,b)]) uk[make_pair(k,b)]=++cnt;
rr int pos=uk[make_pair(k,b)];
rr lll now=K[pos][make_pair(t.x,t.y)];
K[pos][make_pair(t.x,t.y)]=max(now,t.w);
}
}
for (rr int i=1;i<=cnt;++i){
rr lll now=-2e9;
for (it=K[i].begin();it!=K[i].end();++it){
if (now!=-2e9) ans=max(ans,now+(it->second));
now=max(now,it->second);
}
}
sort(A+1,A+1+lA,cmpy),sort(B+1,B+1+lB,cmpx);
for (rr int l=1,r;l<=lA;l=r+1){
for (r=l;A[l].y==A[r].y;++r); --r;
rr int j=l; rr lll now=-2e9;
for (rr int i=l+1;i<=r;++i){
for (;A[j].x<A[i].x;++j) now=max(now,A[j].w);
if (now!=-2e9) ans=max(ans,now+A[i].w);
}
}
for (rr int l=1,r;l<=lB;l=r+1){
for (r=l;B[l].x==B[r].x;++r); --r;
rr int j=l; rr lll now=-2e9;
for (rr int i=l+1;i<=r;++i){
for (;B[j].y<B[i].y;++j) now=max(now,B[j].w);
if (now!=-2e9) ans=max(ans,now+B[i].w);
}
}
if (ans==-4e9) printf("-1");
else printf("%lld",ans);
return 0;
}
H - Security Camera
题目
给出一张 \(n\) 个点,\(m\) 条边的无向图,问有多少个点集相邻的边数量为偶数
\(n\leq 40\)
分析
这个相邻的边不好搞,不过点集的补集要满足其导出子图的边数与 \(m\) 奇偶性相同。
理应用meet in the middle写的,但是其实可用状态很少,直接dp在2s内还是可以跑过的
设 \(dp[i][x][y]\) 表示前 \(i\) 个点之间连边奇偶性为 \(x=0/1\)
且第 \(i\) 个点之后的连边奇偶性状态为 \(y\) 的点集数量
代码
int main(){
n=iut(),m=iut();
for (rr int i=1;i<=m;++i){
rr int x=iut(),y=iut();
a[x]|=1ll<<(y-x-1);//扔掉小于x的状态
}
dp[0][m&1][0]=1;
for (rr int i=0;i<n;++i)
for (rr int j=0;j<2;++j)
for (it=dp[i][j].begin();it!=dp[i][j].end();++it){
rr lll fi=it->first,se=it->second;
dp[i+1][(j^fi)&1][(fi>>1)^a[i+1]]+=se;//选择这个点就要判断与该点连边的边数是否为奇数
dp[i+1][j][fi>>1]+=se;
}
return !printf("%lld",dp[n][0][0]);
}
AtCoder Beginner Contest 220的更多相关文章
- AtCoder Beginner Contest 220部分题(G,H)题解
刚开始的时候被E题卡住了,不过发现是个数学题后就开始使劲推式子,幸运的是推出来了,之后的F题更是树形DP换根的模板吧,就草草的过了,看了一眼G,随便口胡了一下,赶紧打代码,毕竟时间不多了,最后也没打完 ...
- AtCoder Beginner Contest 220 A-F
A #include <iostream> using namespace std; int main() { int a, b, c; cin >> a >> b ...
- AtCoder Beginner Contest 100 2018/06/16
A - Happy Birthday! Time limit : 2sec / Memory limit : 1000MB Score: 100 points Problem Statement E8 ...
- AtCoder Beginner Contest 052
没看到Beginner,然后就做啊做,发现A,B太简单了...然后想想做完算了..没想到C卡了一下,然后还是做出来了.D的话瞎想了一下,然后感觉也没问题.假装all kill.2333 AtCoder ...
- AtCoder Beginner Contest 053 ABCD题
A - ABC/ARC Time limit : 2sec / Memory limit : 256MB Score : 100 points Problem Statement Smeke has ...
- AtCoder Beginner Contest 136
AtCoder Beginner Contest 136 题目链接 A - +-x 直接取\(max\)即可. Code #include <bits/stdc++.h> using na ...
- AtCoder Beginner Contest 137 F
AtCoder Beginner Contest 137 F 数论鬼题(虽然不算特别数论) 希望你在浏览这篇题解前已经知道了费马小定理 利用用费马小定理构造函数\(g(x)=(x-i)^{P-1}\) ...
- AtCoder Beginner Contest 076
A - Rating Goal Time limit : 2sec / Memory limit : 256MB Score : 100 points Problem Statement Takaha ...
- AtCoder Beginner Contest 079 D - Wall【Warshall Floyd algorithm】
AtCoder Beginner Contest 079 D - Wall Warshall Floyd 最短路....先枚举 k #include<iostream> #include& ...
- AtCoder Beginner Contest 064 D - Insertion
AtCoder Beginner Contest 064 D - Insertion Problem Statement You are given a string S of length N co ...
随机推荐
- VS Code实现SSH远程开发
最近收获一台新台式机,但是个人主要还是使用自己的笔记本,用了几天远程控制,感觉各种不方便,最终决定配置一下VS Code实现SSH远程开发,特此记录. 首先介绍一下环境,控制端是Windows 11, ...
- 双层循环练习,pass_break_continue,和for循环---day06
1.双层循环练习 2.pass_break_continue pass:在代码块中无代码可写时,可用pass占位 break:终止当前循环,只能应用在循环里 continue:跳过当前循环,从下一次开 ...
- django中一些快捷函数
1.get_object_or_404() 接收两个参数,参数1为模型类,参数2为查询参数 查询到对象则返回对象,查询不到则返回http404,但是不会返回模型的DoesNotExist异常 示例: ...
- Retrofit 的基本用法
一.添加依赖和网络权限 添加依赖 implementation 'com.squareup.retrofit2:retrofit:2.9.0' implementation 'com.squareup ...
- 【LeetCode回溯算法#11】解数独,这次是真的用回溯法处理二维数组
解数独 力扣题目链接(opens new window) 编写一个程序,通过填充空格来解决数独问题. 一个数独的解法需遵循如下规则: 数字 1-9 在每一行只能出现一次. 数字 1-9 在每一列只能出 ...
- 【LeetCode链表#7】设计一个链表并实现常见的操作方法
设计链表 题目 力扣题目链接 设计链表的实现.您可以选择使用单链表或双链表.单链表中的节点应该具有两个属性:val 和 next.val 是当前节点的值,next 是指向下一个节点的指针/引用.如果要 ...
- Centos系统下,各种服务重启
1.sudo systemctl start firewalld 2../redis-server /usr/local/bin/redis.conf 3.mongod -f /etc/mongod ...
- C++ 模板的笔记2
C++模板的笔记2 关于可变参函数模板借鉴了一部分笔记,感谢大佬 类模板中的嵌套 类模板可以嵌套其他类模板,就像普通类可以嵌套其他普通类一样.嵌套的类模板可以访问外部类模板的成员,包括私有成员. 示例 ...
- RocketMQ(10) 消息类型
一.普通消息 1. 消息发送方式分类 Producer对于消息的发送方式也有多种选择,不同的方式会产生不同的系统效果. 同步发送消息: 同步发送消息是指,Producer发出⼀条消息后,会在收到MQ返 ...
- centos7挂载硬盘(大于2T)
配置方法: 1.root账户下,执行 fdisk -l 命令查看挂载的硬盘设备,假设设备号为/dev/sdb,接下来我们使用parted命令来进行GPT分区 2.使用parted命令进行GPT分区 # ...