Atcoder ABC338 A-D题解

又是一篇姗姗来迟的atcoder题解。

Link:ABC338

Problem A:

妥妥的签到题。

#include 
using namespace std;
int main(){
	string str;
	cin>>str;
	if(int(str[0])<65 || int(str[0])>90){
		cout<<"NO"<122){
			cout<<"NO"<

Problem B:

还是签到题。打个擂台就是了。

#include 
using namespace std;
int cnt[200];
int main(){
	string str;
	cin>>str;
	for(int i=0;i

Problem C:

场上以为是爆搜或者dp,最后喜提300pts......

首先,\Theta (2^{ans})会TLE(我有亲身经历)。所以,考虑贪心。

设我们最后做了x道菜品a,y道菜品b,就可以表示成如下形式:

a_{1}x+b_{1}y\leq q_{1},a_{2}x+b_{2}y\leq q_{2},...,a_{n}x+b_{n}y\leq q_{n}

由于a,b,q都不超过10^6,所以枚举x或y(这里选择y),得到这个式子:

x\leq \left \lfloor \frac{q_{i}-b_{i}y_{i}}{a_{i}} \right \rfloor(1\leq i\leq n,b_{i}y_{i}\leq q_{i})

到这,此题就基本解决了。最后,注意特判a_{i}为0的情况。

#include 
using namespace std;
long long q[15],a[15],b[15];
int main(){
	int n;
	cin>>n;
	for(int i=1;i<=n;i++)	
		cin>>q[i];
	for(int i=1;i<=n;i++)
		cin>>a[i];
	for(int i=1;i<=n;i++)	
		cin>>b[i];
	long long ans=0;
	for(int y=0;y<=1e6;y++){
		bool flag=true;
		for(int i=1;i<=n;i++){
			if(y*b[i]>q[i]){
				flag=false;
				break;
			}
		}
		if(!flag)
			break;
		long long x=LONG_LONG_MAX;
		for(int i=1;i<=n;i++){
			if(a[i]>0)
				x=min(x,floor(q[i]-b[i]*y)*1.0/a[i]);//注意要用fmin
		}
		if(x>=0)
			ans=max(ans,x+y);//同理,要用fmax
	}
	cout<

Problem D:

本题的思路来自SSRS的代码。思路大概就是用dis数组记录长度,枚举删除一条边的影响,最后求一遍前缀和,再打个擂台就OK了。可能不太详细,看代码吧。

#include 
using namespace std;
int x[200005];
int main(){
  	int n,m;
  	cin>>n>>m;
  	for(int i=0;i>x[i];
    	x[i]--;
  	}
  	vector dis(n+1,0);
  	for(int i=0;ib)
      		swap(a,b);
    	dis[a]+=n-(b-a);
    	dis[b]-=n-(b-a);
    	dis[0]+=b-a;
    	dis[a]-=b-a;
    	dis[b]+=b-a;
    	dis[n]-=b-a;
  	}
  	for(int i=0;i

完结撒花~

温馨提示:本期的全部代码直接提交均无法AC,请不要无脑Ctrl C+Ctrl V

你可能感兴趣的:(题解,题解)