AISing Programming Contest 2019 翻车记
A:签到。
#include<iostream>
#include<cstdio>
#include<cstdlib>
#include<cmath>
#include<cstring>
#include<algorithm>
using namespace std;
#define ll long long
int read()
{
int x=,f=;char c=getchar();
while (c<''||c>'') {if (c=='-') f=-;c=getchar();}
while (c>=''&&c<='') x=(x<<)+(x<<)+(c^),c=getchar();
return x*f;
}
int h,w,n;
int main()
{
n=read(),h=read(),w=read();
cout<<(n-w+)*(n-h+);
}
B:签到*2。
#include<iostream>
#include<cstdio>
#include<cstdlib>
#include<cmath>
#include<cstring>
#include<algorithm>
using namespace std;
#define ll long long
#define N 110
int read()
{
int x=,f=;char c=getchar();
while (c<''||c>'') {if (c=='-') f=-;c=getchar();}
while (c>=''&&c<='') x=(x<<)+(x<<)+(c^),c=getchar();
return x*f;
}
int n,a,b,p[N];
int main()
{
n=read(),a=read(),b=read();
for (int i=;i<=n;i++) p[i]=read();
int ans=,x=,y=,z=;
for (int i=;i<=n;i++)
{
if (p[i]<=a) x++;
if (p[i]>a&&p[i]<=b) y++;
if (p[i]>b) z++;
}
cout<<min(x,min(y,z));
}
C:考虑在相邻两异色格间连边,这样同一个连通块的异色点间一定存在合法路径。
#include<iostream>
#include<cstdio>
#include<cstdlib>
#include<cmath>
#include<cstring>
#include<algorithm>
using namespace std;
#define ll long long
#define N 410
int read()
{
int x=,f=;char c=getchar();
while (c<''||c>'') {if (c=='-') f=-;c=getchar();}
while (c>=''&&c<='') x=(x<<)+(x<<)+(c^),c=getchar();
return x*f;
}
int n,m,a[N][N],fa[N*N],size[N*N][];
int trans(int x,int y){return (x-)*m+y;}
int wx[]={,,,-},wy[]={,,-,};
int find(int x){return fa[x]==x?x:fa[x]=find(fa[x]);}
int main()
{
n=read(),m=read();
for (int i=;i<=n;i++)
for (int j=;j<=m;j++)
{
char c=getchar();
while (c!='.'&&c!='#') c=getchar();
a[i][j]=c=='.';
}
for (int i=;i<=n;i++)
for (int j=;j<=m;j++)
{
fa[trans(i,j)]=trans(i,j);
size[trans(i,j)][a[i][j]]=;
}
for (int i=;i<=n;i++)
for (int j=;j<=m;j++)
for (int k=;k<;k++)
if (i+wx[k]>=&&i+wx[k]<=n&&j+wy[k]>=&&j+wy[k]<=m&&a[i+wx[k]][j+wy[k]]!=a[i][j])
{
int p=find(trans(i,j)),q=find(trans(i+wx[k],j+wy[k]));
if (p!=q)
{
fa[p]=q;
size[q][]+=size[p][],size[q][]+=size[p][];
}
}
ll ans=;
for (int i=;i<=n;i++)
for (int j=;j<=m;j++)
if (find(trans(i,j))==trans(i,j)) ans+=1ll*size[trans(i,j)][]*size[trans(i,j)][];
cout<<ans;
}
D:显然分为两个过程,第一个过程中两人取数互不相关,第二个过程中两人从大到小依次取数。二分套二分找到分界点,瞎搞一波前缀和即可。不知道为啥写了一年。
#include<iostream>
#include<cstdio>
#include<cstdlib>
#include<cmath>
#include<cstring>
#include<algorithm>
using namespace std;
#define ll long long
#define N 100010
int read()
{
int x=,f=;char c=getchar();
while (c<''||c>'') {if (c=='-') f=-;c=getchar();}
while (c>=''&&c<='') x=(x<<)+(x<<)+(c^),c=getchar();
return x*f;
}
int n,m,a[N];
ll s[N],f[N];
int findmax(int x,int k)
{
int l=,r=n;
while (l+<r)
{
int mid=l+r>>;
if (mid+k->n) r=mid;
else if (x-a[mid]>a[mid+k-]-x) l=mid;
else r=mid;
}
int ans=l;
for (int i=l+;i<=r;i++)
if (r+k-<=n&&max(x-a[i],a[i+k-]-x)<max(x-a[ans],a[ans+k-]-x)) ans=i;
return a[ans+k-];
}//和x最接近的数中取k个后最大的
bool check(int k,int x)
{
if (k*->n) return ;
//cout<<k<<' '<<x<<endl;
//cout<<findmax(x,1)<<' '<<a[n-k+1]<<endl;
return findmax(x,k-)<a[n-k+];
}
int main()
{
n=read(),m=read();
for (int i=;i<=n;i++) a[i]=read();
sort(a+,a+n+);
s[]=a[];
for (int i=;i<=n;i++) s[i]=s[i-]+a[i];
for (int i=n;i>=;i--) f[i]=f[i+]+a[i];
for (int i=;i<=m;i++)
{
int x=read();
int l=,r=n,t=;
while (l<=r)
{
int mid=l+r>>;
if (check(mid,x)) t=mid,l=mid+;
else r=mid-;
}
//cout<<t<<endl;
ll ans=f[n-t+];int y=n-t*;
if (y>) ans+=s[y];
printf("%lld\n",ans);
}
}
E:正常的想法是设f[i][j]为i子树中包含j的连通块权值和为j时最少要割多少边,显然这样不行,于是就反过来,设f[i][j]为i子树中割j条边能使i所在连通块获得的最小权值和(当然割出的除根以外的连通块均需要合法)。同时设g[i]表示i子树中最少割多少条边能使i所在连通块均为正数(前提同上)。转移类似树形背包。莫名其妙写的非常慢感觉非常恶心。
#include<iostream>
#include<cstdio>
#include<cstdlib>
#include<cmath>
#include<cstring>
#include<algorithm>
using namespace std;
#define ll long long
#define N 5010
int read()
{
int x=,f=;char c=getchar();
while (c<''||c>'') {if (c=='-') f=-;c=getchar();}
while (c>=''&&c<='') x=(x<<)+(x<<)+(c^),c=getchar();
return x*f;
}
int n,a[N],p[N],g[N],size[N],t;
ll sum[N],f[N][N];
struct data{int to,nxt;
}edge[N<<];
void addedge(int x,int y){t++;edge[t].to=y,edge[t].nxt=p[x],p[x]=t;}
void dfs(int k,int from)
{
sum[k]=a[k];
for (int i=p[k];i;i=edge[i].nxt)
if (edge[i].to!=from)
{
dfs(edge[i].to,k);
sum[k]+=sum[edge[i].to];
}
if (a[k]>)
{
g[k]=;
for (int i=p[k];i;i=edge[i].nxt)
if (edge[i].to!=from)
{
int x=g[edge[i].to];
for (int j=;j<=n;j++)
if (f[edge[i].to][j]<) {x=min(x,j+);break;}
g[k]+=x;
}
}
f[k][]=a[k];
size[k]=;
for (int i=p[k];i;i=edge[i].nxt)
if (edge[i].to!=from)
{
for (int j=size[k]+size[edge[i].to];j>=;j--)
{
f[k][j]+=sum[edge[i].to];if (j-g[edge[i].to]->=) f[k][j]=min(f[k][j],f[k][j-g[edge[i].to]-]);
for (int x=max(,j-size[k]);x<=min(j,size[edge[i].to]);x++)
{
if (x) f[k][j]=min(f[k][j],f[k][j-x]+f[edge[i].to][x]);
if (x<j&&f[edge[i].to][x]<) f[k][j]=min(f[k][j],f[k][j-x-]);
}
}
size[k]+=size[edge[i].to];
}
}
int main()
{
/*freopen("e.in","r",stdin);
freopen("e.out","w",stdout);*/
n=read();
for (int i=;i<=n;i++) a[i]=read();
for (int i=;i<n;i++)
{
int x=read(),y=read();
addedge(x,y),addedge(y,x);
}
memset(g,,sizeof(g));
memset(f,,sizeof(f));
dfs(,);
/*for (int i=1;i<=n;i++) cout<<a[i]<<' ';cout<<endl;
for (int i=1;i<=n;i++) cout<<g[i]<<' ';cout<<endl;
cout<<endl;
for (int i=1;i<=n;i++)
{
for (int j=0;j<n;j++)
cout<<f[i][j]<<' ';
cout<<endl;;
}
for (int i=1;i<=n;i++) cout<<sum[i]<<' ';cout<<endl;*/
int ans=g[];
for (int i=;i<=n;i++)
if (f[][i]<) {ans=min(ans,i);break;}
cout<<ans;
return ;
}
为什么算rating的时候不把unrated的去掉啊。result:rank 43 rating +138
AISing Programming Contest 2019 翻车记的更多相关文章
- NIKKEI Programming Contest 2019 翻车记
A:签到. #include<iostream> #include<cstdio> #include<cstdlib> #include<cstring> ...
- 【AtCoder】AISing Programming Contest 2019
本来以为是1199rated的..仔细一看发现是1999,所以就做了一下 这场涨分很轻松啊...为啥又没打 等pkuwc考完我一定打一场atcoder(咕咕咕,咕咕咕,咕咕咕咕咕咕咕~) 但是其实我思 ...
- AISing Programming Contest 2019 Solution
A - Bulletin Board 签到. #include <bits/stdc++.h> using namespace std; int main() { int n, h, w; ...
- Dwango Programming Contest V 翻车记
A:签到. #include<iostream> #include<cstdio> #include<cmath> #include<cstdlib> ...
- AtCoder AISing Programming Contest 2019 Task D. Nearest Card Game
题目分析在代码注释里. int main() { #if defined LOCAL && !defined DUIPAI ifstream in("main.in" ...
- [AtCoder] NIKKEI Programming Contest 2019 (暂缺F)
[AtCoder] NIKKEI Programming Contest 2019 本来看见这一场的排名的画风比较正常就来补一下题,但是完全没有发现后两题的AC人数远少于我补的上一份AtCoder ...
- [AtCoder] Yahoo Programming Contest 2019
[AtCoder] Yahoo Programming Contest 2019 很遗憾错过了一场 AtCoder .听说这场是涨分场呢,于是特意来补一下题. A - Anti-Adjacency ...
- Yahoo Programming Contest 2019 自闭记
A:签到. #include<iostream> #include<cstdio> #include<cmath> #include<cstdlib> ...
- KEYENCE Programming Contest 2019 自闭记
A:签到. #include<iostream> #include<cstdio> #include<cstdlib> #include<cmath> ...
随机推荐
- Android学习之基础知识四-Activity活动8讲(活动的灵活运用)
一.判断当前是在哪个活动 1.我们还是接着上一讲的代码,首先创建一个Java类:BaseActivity.java.这个类我们不作为一个活动,也不在AndroidManifest.xml中注册,它只是 ...
- ftp 传输数据:命令链路连接方法是一样的,而数据链路的建立方法就完全不同
0.FTP协议有两种工作方式:PORT方式和PASV方式,中文意思为主动式和被动式. PORT(主动)连接过程是:客户端向服务器的FTP端口(默认是21)发送连接请 求,服务器接受连接,建立一条命令链 ...
- Zephyr的Logging
1 前言 刚接触Zephyr,两眼一抹黑,光是阅读代码对系统没什么概念.还需要通过一些日志了解系统的运行机制,以及各种内核行为. 这就需要借助系统的Logging,大体分为两部分System Logg ...
- SkylineGlobe6.5版本,在矿山、石油、天然气等能源行业的最新应用DEMO演示
SkylineGlobe6.5版本,在矿山.石油.天然气等能源行业的最新应用DEMO演示: http://v.youku.com/v_show/id_XNTc3Njc1OTEy.html 一个Pres ...
- CF293B Distinct Paths 搜索
传送门 首先数据范围很假 当\(N + M - 1 > K\)的时候就无解 所以对于所有要计算的情况,\(N + M \leq 11\) 超级小是吧,考虑搜索 对于每一个格子试填一个数 对于任意 ...
- SPI内容随笔
关于SPI的通信: SPI采用的是主从模式的同步通信,通过时钟来控制:一般情况下,使用双向全双工,收发的数据放在缓冲器FIFO中.数据的传输是主SPI的时钟在控制,从机是不能产生时钟的,如果没有时钟, ...
- item 10: 比起unscoped enum更偏爱scoped enum
本文翻译自modern effective C++,由于水平有限,故无法保证翻译完全正确,欢迎指出错误.谢谢! 博客已经迁移到这里啦 一般情况下,在花括号中声明一个name(包括变量名,函数名),这个 ...
- [UWP 自定义控件]了解模板化控件(10):原则与技巧
1. 原则 推荐以符合以下原则的方式编写模板化控件: 选择合适的父类:选择合适的父类可以节省大量的工作,从UWP自带的控件中选择父类是最安全的做法,通常的选择是Control.ContentContr ...
- Mac下通过VMware Fusion安装centos虚拟机操作记录
下面介绍下利用VMware Fusion工具在Mac上安装centos虚拟机的做法:1)下载VMware Fusion工具下载地址(包括注册码):http://www.macx.cn/thread-2 ...
- VS2015安装及单元测试
今天跟大家分享一下我的VS2015的安装过程以及对单元测试的操作步骤.VS2015是一款非常好用的编程软件,内容很多很广泛,是深受欢迎的一款软件,较之于VC++6.0有着一些好处,对VC6.0++来说 ...