Yahoo Programming Contest 2019 自闭记

  A:签到。

#include<iostream>
#include<cstdio>
#include<cmath>
#include<cstdlib>
#include<cstring>
#include<algorithm>
using namespace std;
#define ll long long
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 main()
{
	int n=read(),m=read();
	if (m*2-1<=n) cout<<"YES";else cout<<"NO";
	return 0;
}

  B:直接按欧拉路判,才不管只有四个点。

#include<iostream>
#include<cstdio>
#include<cmath>
#include<cstdlib>
#include<cstring>
#include<algorithm>
using namespace std;
#define ll long long
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 a[5],fa[5];
int find(int x){return fa[x]==x?x:fa[x]=find(fa[x]);}
int main()
{
	for (int i=1;i<=4;i++) fa[i]=i;
	for (int i=1;i<=3;i++)
	{
		int x=read(),y=read();
		a[x]++,a[y]++;fa[find(x)]=find(y);
	}
	for (int i=1;i<=4;i++)
	if (find(i)!=find(1)) {cout<<"NO";return 0;}
	int cnt=0;
	for (int i=1;i<=4;i++)
	{
		if (a[i]&1) cnt++;
	}
	if (cnt==2) cout<<"YES";
	else {cout<<"NO";return 0;}
	return 0;
}

  C:相当于可以用1代价获得1收益,用2代价获得b-a收益。瞎讨论即可。注意2代价获得b-a收益的前提是当前有至少a块饼干。

#include<iostream>
#include<cstdio>
#include<cmath>
#include<cstdlib>
#include<cstring>
#include<algorithm>
using namespace std;
#define ll long long
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 main()
{
	int n=read(),a=read(),b=read();
	b-=a;
	if (b<=2) cout<<n+1;
	else
	{
		if (n<a) cout<<n+1;
		else
		{
			n-=a-1;
			ll ans=a;
			ans+=1ll*b*(n/2);
			if (n&1) ans++;
			cout<<ans;
		}
	}
	return 0;
}

  D:相当于找一个形如0 非零偶数 奇数 非零偶数 0 的序列(每一段长度任意且可以为空),使该序列与原序列差的绝对值之和最小。赛时智商急剧下降搞了一大堆前缀和,最后屯完题交的时候网又卡了,发现wa掉的时候只剩下5min,于是就没救了。实际上直接dp不能再好写,即f[i][0/1/2/3/4]表示第i个位置在第j段中时的最小和。

#include<iostream>
#include<cstdio>
#include<cmath>
#include<cstdlib>
#include<cstring>
#include<algorithm>
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,a[N],delta[N];
ll f[N][5];
//ll ans,f[N][2],s[N],g[N][2],h[N];
int main()
{
	n=read();
	for (int i=1;i<=n;i++) a[i]=read();
	/*for (int i=1;i<=n;i++)
	if (a[i]==0) delta[i]=2;
	else delta[i]=a[i]&1;
	for (int i=1;i<=n;i++) g[i][0]=g[i-1][0]+delta[i],s[i]=s[i-1]+a[i];
	ll u=0;
	for (int i=1;i<=n;i++)
	{
		u=min(u,s[i]-g[i][0]);
		f[i][0]=g[i][0]+u;
	}
	for (int i=n;i>=1;i--) g[i][1]=g[i+1][1]+delta[i],s[i]=s[i+1]+a[i];
	u=0;
	for (int i=n;i>=1;i--)
	{
		u=min(u,s[i]-g[i][1]);
		f[i][1]=g[i][1]+u;
	}
	for (int i=1;i<=n;i++) ans+=a[i];
	u=0;
	for (int i=1;i<=n;i++) ans=min(ans,f[i][1]+s[i-1]);
	for (int i=1;i<=n;i++) h[i]=h[i-1]+(a[i]&1^1);
	for (int i=1;i<=n+1;i++)
	{
		ans=min(ans,f[i][1]+u+h[i-1]);
		u=min(u,f[i][0]-h[i]);
	}*/
	for (int i=1;i<=n;i++)
	{
		f[i][0]=f[i-1][0];
		for (int j=1;j<=4;j++)
		f[i][j]=min(f[i][j-1],f[i-1][j]);
		f[i][0]+=a[i],f[i][4]+=a[i];
		f[i][1]+=a[i]==0?2:(a[i]&1);
		f[i][3]+=a[i]==0?2:(a[i]&1);
		f[i][2]+=a[i]&1^1;
	}
	ll ans=f[n][0];for (int i=1;i<=4;i++) ans=min(ans,f[n][i]);
	cout<<ans;
	return 0;
}

  F:大胆猜想序列合法当且仅当序列前i个位置的红球个数<=前i个人的红球个数,序列前i个位置的蓝球个数<=前i个人的蓝球个数,然后就是个思博dp了。

#include<iostream>
#include<cstdio>
#include<cmath>
#include<cstdlib>
#include<cstring>
#include<algorithm>
using namespace std;
#define ll long long
#define N 2010
#define P 998244353
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],u,v,s[N][2],f[N<<1][N<<1];
char S[N];
void inc(int &x,int y){x+=y;if (x>=P) x-=P;}
int main()
{
	scanf("%s",S+1);
	n=strlen(S+1);
	for (int i=1;i<=n;i++) a[i]=S[i]-‘0‘;
	for (int i=1;i<=n;i++) u+=2-a[i],v+=a[i];
	for (int i=1;i<=n;i++) s[i][0]=s[i-1][0]+2-a[i],s[i][1]=s[i-1][1]+a[i];
	f[0][0]=1;
	for (int i=0;i<=u;i++)
		for (int j=0;j<=v;j++)
		if (i|j)
		{
			if (s[min(n,i+j)][0]>=i&&s[min(n,i+j)][1]>=j)
			{
				if (i) inc(f[i][j],f[i-1][j]);
				if (j) inc(f[i][j],f[i][j-1]);
			}
		}
	cout<<f[u][v];
	return 0;
}

  result:rank 207 rating +38 莫名其妙上黄了但非常不爽啊。

E:当行集合确定后,只要这些行的异或不为0,列的选择方案就有2^(m-1)种(似乎是一个在玛里苟斯中出现过的结论)。子集异或和为0容易想到线性基(高斯消元),同时注意到交换/异或两行不会改变答案,于是高斯消元后得到矩阵的秩,答案就显然了。

原文地址:https://www.cnblogs.com/Gloid/p/10358542.html

时间: 2024-11-09 16:15:10

Yahoo Programming Contest 2019 自闭记的相关文章

diverta 2019 Programming Contest 2自闭记

A 签到(a-b problem不用贴了吧,以后atcoder小于300分题均不贴代码) B 发现选择的p,q一定是其中两点间的距离,于是可以O(n2)枚举两点,再O(n2)判断,其实可以做到O(n3)不过O(n4)就够了. #include<bits/stdc++.h> using namespace std; typedef long long ll; int n,ans; ll x[52],y[52]; int main() { scanf("%d",&n);

Atcoder Yahoo Programming Contest 2019 简要题解

A-C 直接放代码吧. A int n,k; int main() { n=read();k=read(); puts(k<=(n+1)/2?"YES":"NO"); return 0; } B int d[N];pair<int,int>s[10]; int main() { for(int i=1,u,v;i<=3;i++){ u=read();v=read(); s[i].first=u;s[i].second=v; d[u]++;d[

Yahoo Programming Contest 2019

A - Anti-Adjacency 签. 1 #include <bits/stdc++.h> 2 using namespace std; 3 4 int main() 5 { 6 int n, k; 7 while (scanf("%d%d", &n, &k) != EOF) 8 { 9 int remind = (n + 1) / 2; 10 puts(k <= remind ? "YES" : "NO"

Yahoo Programming Contest 2019 D - Ears

D - Ears 思路: s:起点           t:终点           l:左端点           r:右端点 以上称为关键点 dp[i][j]表示到位置 i 为止,已经经过前 j 个关键点的最小花费 转移方程看代码: #pragma GCC optimize(2) #pragma GCC optimize(3) #pragma GCC optimize(4) #include<bits/stdc++.h> using namespace std; #define y1 y1

Yahoo Programming Contest 2019 F - Pass

F - Pass 思路: dp[i][j] 表示到第 i 个球为止放了 j 个蓝球的方案数 第 i 个球来自的位置的最右边是min(i, n) 转移方程看代码 代码: #pragma GCC optimize(2) #pragma GCC optimize(3) #pragma GCC optimize(4) #include<bits/stdc++.h> using namespace std; #define y1 y11 #define fi first #define se secon

Yahoo Programming Contest 2019.E.Odd Subrectangles(思路 线性基)

题目链接 \(Description\) 给定一个\(n\times m\)的\(01\)矩阵.求任意选出\(r\)行.\(c\)列(共\(2^{n+m}\)种方案),使得这\(r\)行\(c\)列的交的位置的\(r\times c\)个数的和为奇数,的方案数有多少. (...我也不知道怎么就表述成这样了,反正挺好理解) \(n,m\leq300\). \(Solution\) 假设已经确定了选择某些行,然后把每一行\(m\)个数看做一个\(m\)位二进制数. 如果这些行异或和为\(0\),那怎

2020-3-14 acm训练联盟周赛Preliminaries for Benelux Algorithm Programming Contest 2019 解题报告+补题报告

2020-3-15比赛解题报告+2020-3-8—2020-3-15的补题报告 2020-3-15比赛题解 训练联盟周赛Preliminaries for Benelux Algorithm Programming Contest 2019  A建筑(模拟) 耗时:3ms 244KB 建筑 你哥哥在最近的建筑问题突破大会上获得了一个奖项 并获得了千载难逢的重新设计城市中心的机会 他最喜欢的城市奈梅根.由于城市布局中最引人注目的部分是天际线, 你的兄弟已经开始为他想要北方和东方的天际线画一些想法

[AtCoder] NIKKEI Programming Contest 2019 (暂缺F)

[AtCoder] NIKKEI Programming Contest 2019 ??本来看见这一场的排名的画风比较正常就来补一下题,但是完全没有发现后两题的AC人数远少于我补的上一份AtCoder. A - Subscribers ??首先始终 \(max = \min(A, B)\) ,\(min\) 的话如果 \(A + B \leq N\) ,那么就是 \(0\) ,否则就是 \(A + B - N\) . int n, a, b; int main() { read(n), read

NIKKEI Programming Contest 2019 翻车记

A:签到. #include<iostream> #include<cstdio> #include<cstdlib> #include<cstring> #include<cmath> #include<algorithm> using namespace std; int gcd(int n,int m){return m==0?n:gcd(m,n%m);} int read() { int x=0,f=1;char c=getc