迷宫大门(door)

迷宫大门(door)

在跳棋游戏大获全胜后,小明就开始一个人在校园里溜达了。突然他在校园角落里发现了一面神奇的墙壁,墙壁上有一排钉子,每个钉子上都挂着一根两端系有小球的绳子,如下图所示:
在这里插入图片描述

小明可以调整每一根绳子在钉子左右两端的长度,当来自不同绳子的相邻小球高度一样时(具体可见样例说明),便可获得积分1分。当小明的方案获得最高积分时,迷宫大门就会开启,小明就可以进去寻找宝藏啦!

这是第四题?既然如此的水,一个贪心就解决了!
可以不知道为什么比赛时只有11.7分。
进过大佬的讲解,我终于大悟!

题目思路,这道题我们可以用贪心来做(人人都知道,可我竟然没有对),我们一开始我们用一个数组来记录每一颗钉子的可调动的长度。然后做一遍贪心就行了

code:

#include<cstdio>
#include<iostream>
using namespace std;
int a[500010];
int main()
{
	freopen("door.in","r",stdin);
	freopen("door.out","w",stdout);
	int n,u,c,ans=0;
	cin>>n; 
	for(int i=1;i<=n;i++)
	{
		cin>>u>>c;
		a[i]=u+c;
	}
	int minn=0,maxx=a[1];
	for(int i=2;i<=n;i++)
	{
		if(a[i]<minn)
		{
			minn=0;
			maxx=a[i];
		}
		else
		{
			++ans;
			int x,y;
			x=a[i]-min(maxx,a[i]);
			y=a[i]-minn;
			minn=x;
			maxx=y;
		}
	}
	cout<<ans<<endl;
	return 0;
}

谢谢

发布了80 篇原创文章 · 获赞 58 · 访问量 2518

猜你喜欢

转载自blog.csdn.net/bigwinner888/article/details/104541339
今日推荐