Codeforces Round 558(Div 2)题解
这场比赛没有打,后来和同学们一起开了场镜像打……
B是SB题结果WA了5发……
C是SB题结果差5min调出……虽然中间有个老师讲题吃掉了1h
D是比较神仙的题(2200),但是做出来了?算是比较超常发挥了。(平常能做出的题中最难的就是2200了)
E是2800,F是2900,zblzbl……
这次发挥还是不错的,写一篇题解吧。
A
首先发现在一个圆上删掉 $m$ 个点,段数的上界为 $m$。($0$ 除外,所以要特判 $0$)
然后剩下了 $n-m$ 个点。答案就是 $\min(m,n-m)$。
#include<bits/stdc++.h>
using namespace std;
#define FOR(i,a,b) for(int i=(a);i<=(b);i++)
#define ROF(i,a,b) for(int i=(a);i>=(b);i--)
#define MEM(x,v) memset(x,v,sizeof(x))
inline int read(){
int x=,f=;char ch=getchar();
while(ch<'' || ch>'') f|=ch=='-',ch=getchar();
while(ch>='' && ch<='') x=x*+ch-'',ch=getchar();
return f?-x:x;
}
int main(){
int n=read(),m=read();
if(!m) printf("%d\n",);
else printf("%d\n",min(m,n-m));
}
B1/B2
枚举 $k$ 看看可不可行。
与数出现次数有关,给数开个桶。
对于B1,直接大暴力讨论即可。
对于B2,对桶再开个桶,就能优化暴力。
时间复杂度 $O(n)$。(细节太多了,就WA了5发……)
#include<bits/stdc++.h>
using namespace std;
const int maxn=,mod=;
#define lson o<<1,l,mid
#define rson o<<1|1,mid+1,r
#define FOR(i,a,b) for(int i=(a);i<=(b);i++)
#define ROF(i,a,b) for(int i=(a);i>=(b);i--)
#define MEM(x,v) memset(x,v,sizeof(x))
inline int read(){
int x=,f=;char ch=getchar();
while(ch<'' || ch>'') f|=ch=='-',ch=getchar();
while(ch>='' && ch<='') x=x*+ch-'',ch=getchar();
return f?-x:x;
}
int n,c1[maxn],c2[maxn],cnt,ans;
int main(){
n=read();
FOR(i,,n){
int w=read();
c2[c1[w]]--;
if(!c2[c1[w]]) cnt--;
c1[w]++;
c2[c1[w]]++;
if(c2[c1[w]]==) cnt++;
if(cnt== && (c1[w]== || c2[c1[w]]==) || (cnt== && (c2[c1[w]+]== || c2[c1[w]]== && c2[c1[w]-] || c2[]==))) ans=max(ans,i);
}
printf("%d\n",ans);
}
C1/C2
C1大暴力,没啥好说的。
C2反向考虑,斜率相同的直线对数。
记得去重。记得特判没有斜率($x$ 坐标相同)。
时间复杂度 $O(n^2\log n)$。(实现够好可以 $O(n^2)$?)
#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
const int maxn=;
const double eps=1e-;
#define FOR(i,a,b) for(int i=(a);i<=(b);i++)
#define ROF(i,a,b) for(int i=(a);i>=(b);i--)
#define MEM(x,v) memset(x,v,sizeof(x))
inline int read(){
int x=,f=;char ch=getchar();
while(ch<'' || ch>'') f|=ch=='-',ch=getchar();
while(ch>='' && ch<='') x=x*+ch-'',ch=getchar();
return f?-x:x;
}
struct line{
double k,b;
bool operator<(const line &l)const{
if(fabs(k-l.k)>eps) return k<l.k;
return b<l.b;
}
bool operator==(const line &l)const{
return fabs(k-l.k)<eps && fabs(b-l.b)<eps;
}
}l[maxn*maxn];
int n,x[maxn],y[maxn],m,cnt[],ccc;
ll ans;
int main(){
n=read();
FOR(i,,n) x[i]=read(),y[i]=read();
FOR(i,,n) FOR(j,i+,n){
if(x[i]==x[j]){
cnt[x[i]+]++;
if(cnt[x[i]+]==) ccc++;
continue;
}
double k=1.0*(y[i]-y[j])/(x[i]-x[j]);
l[++m]=(line){k,y[i]-k*x[i]};
}
sort(l+,l+m+);
m=unique(l+,l+m+)-l-;
ans=1ll*m*(m-)/+1ll*m*ccc;
for(int ll=,rr;ll<=m;ll=rr+){
rr=ll;
while(rr<=m && fabs(l[ll].k-l[rr].k)<eps) rr++;
rr--;
ans-=1ll*(rr-ll+)*(rr-ll)/;
}
cout<<ans<<endl;
}
D
考虑DP,$f[i][j][k]$ 表示 $c$ 的前 $i$ 个字符替换完了,$s$ 能匹配到前缀 $j$,$t$ 能匹配到前缀 $k$ 的最大值。
初始,$f[0][0][0]=0$,其他为 -INF。
转移,可以从 $f[i][j][k]$ 到 $f[i+1][j'][k'](0/+1/-1)$。后面的 $0/+1/-1$ 就要判断 $s$ 和 $t$ 是否可以匹配。
答案为 $\max(f[|c|][j][k])$。此时时间复杂度为 $O(|c||s|^3|t|^3|A|)$,优秀一点可以做到 $O(|c||s||t||A|+(|s|^3+|t|^3)|A|)$。(预处理 $to_s[i][c]$ 表示从 $s$ 的第 $i$ 个字符扩展一个 $c$ 最远能是哪个前缀,$t$ 类似)
此时已经可以通过本题,然而我SB没想到预处理 $to_s$,所以用了 KMP 优化找 $j'$ 和 $k'$。
时间复杂度 $O(|c||s||t||A|)$。
似乎可以用AC自动机或者讨论 $j$ 和 $k$ 的大小关系继续优化。
#include<bits/stdc++.h>
using namespace std;
const int maxn=,mod=;
#define lson o<<1,l,mid
#define rson o<<1|1,mid+1,r
#define FOR(i,a,b) for(int i=(a);i<=(b);i++)
#define ROF(i,a,b) for(int i=(a);i>=(b);i--)
#define MEM(x,v) memset(x,v,sizeof(x))
inline int read(){
int x=,f=;char ch=getchar();
while(ch<'' || ch>'') f|=ch=='-',ch=getchar();
while(ch>='' && ch<='') x=x*+ch-'',ch=getchar();
return f?-x:x;
}
int l,n,m,f[maxn][][],nxts[],nxtt[],ans=-1e9;
char c[maxn],s[],t[];
void get_nxt(char s[],int l,int nxt[]){
int j=;
FOR(i,,l){
while(j && s[i]!=s[j+]) j=nxt[j];
if(s[i]==s[j+]) j++;
nxt[i]=j;
}
}
inline void chkmax(int &x,int y){if(y>x) x=y;}
void use(int i,int j,int k,char x){
int jj=j,kk=k;
while(jj && x!=s[jj+]) jj=nxts[jj];
if(x==s[jj+]) jj++;
while(kk && x!=t[kk+]) kk=nxtt[kk];
if(x==t[kk+]) kk++;
if(jj==n){
if(kk==m) chkmax(f[i+][nxts[n]][nxtt[m]],f[i][j][k]);
else chkmax(f[i+][nxts[n]][kk],f[i][j][k]+);
}
else{
if(kk==m) chkmax(f[i+][jj][nxtt[m]],f[i][j][k]-);
else chkmax(f[i+][jj][kk],f[i][j][k]);
}
}
int main(){
scanf("%s%s%s",c+,s+,t+);
l=strlen(c+);n=strlen(s+);m=strlen(t+);
get_nxt(s,n,nxts);
get_nxt(t,m,nxtt);
MEM(f,~0x3f);
f[][][]=;
FOR(i,,l-) FOR(j,,n) FOR(k,,m){
if(c[i+]!='*') use(i,j,k,c[i+]);
else FOR(x,'a','z') use(i,j,k,x);
}
FOR(j,,n) FOR(k,,m) ans=max(ans,f[l][j][k]);
printf("%d\n",ans);
}
E/F
会了再来填吧。
Codeforces Round 558(Div 2)题解的更多相关文章
- Codeforces Round #558 (Div. 2)
目录 Codeforces Round #558 (Div. 2) 题解 A Eating Soup B Cat Party C Power Transmission D Mysterious Cod ...
- Codeforces Round #182 (Div. 1)题解【ABCD】
Codeforces Round #182 (Div. 1)题解 A题:Yaroslav and Sequence1 题意: 给你\(2*n+1\)个元素,你每次可以进行无数种操作,每次操作必须选择其 ...
- Codeforces Round #608 (Div. 2) 题解
目录 Codeforces Round #608 (Div. 2) 题解 前言 A. Suits 题意 做法 程序 B. Blocks 题意 做法 程序 C. Shawarma Tent 题意 做法 ...
- Codeforces Round #525 (Div. 2)题解
Codeforces Round #525 (Div. 2)题解 题解 CF1088A [Ehab and another construction problem] 依据题意枚举即可 # inclu ...
- Codeforces Round #528 (Div. 2)题解
Codeforces Round #528 (Div. 2)题解 A. Right-Left Cipher 很明显这道题按题意逆序解码即可 Code: # include <bits/stdc+ ...
- Codeforces Round #466 (Div. 2) 题解940A 940B 940C 940D 940E 940F
Codeforces Round #466 (Div. 2) 题解 A.Points on the line 题目大意: 给你一个数列,定义数列的权值为最大值减去最小值,问最少删除几个数,使得数列的权 ...
- Codeforces Round #677 (Div. 3) 题解
Codeforces Round #677 (Div. 3) 题解 A. Boring Apartments 题目 题解 简单签到题,直接数,小于这个数的\(+10\). 代码 #include &l ...
- Codeforces Round #665 (Div. 2) 题解
Codeforces Round #665 (Div. 2) 题解 写得有点晚了,估计都官方题解看完切掉了,没人看我的了qaq. 目录 Codeforces Round #665 (Div. 2) 题 ...
- Codeforces Round #160 (Div. 1) 题解【ABCD】
Codeforces Round #160 (Div. 1) A - Maxim and Discounts 题意 给你n个折扣,m个物品,每个折扣都可以使用无限次,每次你使用第i个折扣的时候,你必须 ...
随机推荐
- 利用SQL计算两个地理坐标(经纬度)之间的地表距离
两个地理坐标(经纬度)地表距离计算公式: 公式解释如下: Long1,Lat1表示A点经纬度,Long2,Lat2表示B点经纬度: a=Lat1–Lat2 为两点纬度之差,b=Long1-Long2为 ...
- MarkDown的一些基本语法
Markdown是一种可以使用普通文本编辑器编写的标记语言,通过简单的标记语法,它可以使普通文本内容具有一定的格式. Markdown的语法简洁明了.学习容易,而且功能比纯文本更强,因此有很多人用它写 ...
- Linux(01):linux的起源、应用场景和学习目标
- CSS实现水平垂直居中的数种方法整合
CSS实现水平垂直居中可以说是前端老生常谈的问题了,一般面试官问的时候面试者都会回答出来,但是继续追问还有没有其他方法的时候有可能就说不出来了. 本着学习知识的目的,特在此纪录CSS实现水平垂直居中的 ...
- Kafka producer异步发送在某些情况会阻塞主线程,使用时候慎重
最近发现一个Kafka producer异步发送在某些情况会阻塞主线程,后来在排查解决问题过程中发现这可以算是Kafka的一个说明不恰当的地方. 问题说明 在很多场景下我们会使用异步方式来发送Kafk ...
- pod install速度慢,pod repo update 速度慢解决方法
相信大家已经感受到pod install速度越来越慢了,网上提供了几种解决方案,但是都没有完全解决速度慢的问题. 使用国内镜像的Specs 在pod install时使用命令pod install - ...
- C# HttpWebRequest和WebClient的区别 通过WebClient/HttpWebRequest实现http的post/get方法
一 HttpWebReques1,HttpWebRequest是个抽象类,所以无法new的,需要调用HttpWebRequest.Create();2,其Method指定了请求类型,这里用的GET,还 ...
- ELK——Elasticsearch 搭建集群经验
本文内容 背景 ES集群中第一个master节点 ES slave节点 迁移到:http://www.bdata-cap.com/newsinfo/1712679.html 本文总结 Elastics ...
- SpringBoot嵌入式Tomcat的自动配置原理
在读本篇文章之前如果你读过这篇文章SpringBoot自动装配原理解析应该会更加轻松 准备工作 我们知道SpringBoot的自动装配的秘密在org.springframework.boot.auto ...
- .net Redis分布式锁,Dictionary,ConcurrentDictionary 介绍
1.背景 在计算机世界里,对于锁大家并不陌生,在现代所有的语言中几乎都提供了语言级别锁的实现,为什么我们的程序有时候会这么依赖锁呢?这个问题还是要从计算机的发展说起,随着计算机硬件的不断升级,多核cp ...