P1324 矩形分割 WA 0分求调
  • 板块题目总版
  • 楼主zhaozejian
  • 当前回复15
  • 已保存回复15
  • 发布时间2024/10/25 20:20
  • 上次更新2024/10/25 20:56:17
查看原帖
P1324 矩形分割 WA 0分求调
1013319
zhaozejian楼主2024/10/25 20:20

题目传送门
rt,代码如下:

#include<bits/stdc++.h>
using namespace std;
int n,m,a[2005],b[2005],aa[2005],bb[2005];
long long ans;
int main(){
	cin>>n>>m;
	for(int i=1;i<n;i++)
	{
		cin>>a[i];
		aa[i]=1;//a[i]要切几次(默认1次)
	}
	sort(a+1,a+n);
	for(int i=1;i<m;i++)
	{
		cin>>b[i];
		bb[i]=1;//b[i]要切几次(默认1次)
	}
	sort(b+1,b+m);
	int l=n-1,r=m-1;
	while(1)
	{
		if(l<1&&r<1)
		{
			break;
		}
		if(l<1)
		{
			ans+=b[r]*bb[r];
			r--;
			for(int i=1;i<n;i++)
			{
				aa[i]++;
			}
		}
		else if(r<1)
		{
			ans+=a[l]*aa[l];
			l--;
			for(int i=1;i<m;i++)
			{
				bb[i]++;
			}
		}
		else if(a[l]*aa[l]>b[r]*bb[r])
		{
			ans+=a[l]*aa[l];
			l--;
			for(int i=1;i<m;i++)
			{
				bb[i]++;
			}
		}
		else 
		{
			ans+=b[r]*bb[r];
			r--;
			for(int i=1;i<n;i++)
			{
				aa[i]++;
			}
		}
    	//cout<<ans<<" ";
	}
	cout<<ans;
	return 0;
}
2024/10/25 20:20
加载中...