栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > C/C++/C#

Minimal Coverage

C/C++/C# 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

Minimal Coverage

Minimal Coverage
题意:n根棒,按次序放置,后一根棒的起点为前一根棒的终点,可左右放置,求最后最小覆盖面积
思路:dp[i][j]为前 i 根棒放完后以终点位子 j 结束的最小覆盖面积。(最坏情况为最大长度*2)
状态转移方程:

if(j<=a[i])  dp[i][0]=min(dp[i][0],dp[i-1][j]+a[i]-j);//向左放(ai的长度向左放之后终点为负数了,则可以右端点向右移,使得左端点为0)
else  dp[i][j-a[i]]=min(dp[i][j-a[i]],dp[i-1][j]);//向左放
dp[i][j+a[i]]=min(dp[i][j+a[i]],max(dp[i-1][j],a[i]+j));//向右放
#pragma GCC optimize(2)
#pragma GCC optimize(3,"Ofast","inline")
#include
#define int long long
#define IOS ios::sync_with_stdio(false);cin.tie(0);cout.tie(0);
using namespace std;
const int inf=2e18+100;
const int maxn=1e4+100;
int a[maxn];
int dp[maxn][2100];
signed main()
{
	IOS
	int tt;
	cin>>tt;
	while(tt--)
	{
		int n;
		cin>>n;
		for(int i=1; i<=n; i++)
		{
			cin>>a[i];
		}
		for(int i=0; i<=n; i++)
		{
			for(int j=0; j<=2010; j++)
			{
				dp[i][j]=inf;
			}
		}
		dp[0][0]=0;
		for(int i=1; i<=n; i++)
		{
			for(int j=0; j<=2010; j++)
			{
				if(j<=a[i])
				{
					dp[i][0]=min(dp[i][0],dp[i-1][j]+a[i]-j);//向左放
				}
				else
				{
					dp[i][j-a[i]]=min(dp[i][j-a[i]],dp[i-1][j]);//向左放
				}
				dp[i][j+a[i]]=min(dp[i][j+a[i]],max(dp[i-1][j],a[i]+j));//向右放
			}
		}
		int ans=inf;
		for(int i=0; i<=2010; i++)
		{
			ans=min(ans,dp[n][i]);
		}
		cout<
转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/290263.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号