Snow Boots

Snow Boots
题面


题意
大意就是有n块瓦片,每一个瓦片都有一个雪的深度,第一片跟最后一片的雪深度是0. 现在有b双靴子,每一双靴子都有一个最大能经过的积雪数量和最远能跨越的瓦片数而且确保一定可以走到终点,问最少使用多少双靴子可以走到终点。.
分析
这题一开始我是准备用贪心来做的,可是我忽略一种情况。比如
0 1 4 8 8 8 8 8 1 8 8 8 8 0
4 2
3 10
8 1
如果按照一直贪心地走没有考虑到换的鞋能经过的积雪量也要大于等于当前积雪量的话就得出2这个答案。在深度为1的地方换2号鞋,就可以只扔一双走完。那其实我们在思考这个问题的时候是不是考虑了前后两个状态的转移,这就是dp的本质。dp[i]表示第i个位置所需要最小的鞋数,我们就可以从第1、2、…i-1个位置更新,然后逐步考虑这些位置。遍历更新,需要考虑是不换鞋还是换一双鞋还是换两双鞋…然后就可以得到第i个位置所需要最小双鞋数。

AC代码

#include <bits/stdc++.h>
using namespace std;
typedef long long ll;
const ll maxn=255;
const ll inf=1e9+10;
ll n,b,nd[maxn],s[maxn],wd[maxn],dp[maxn];///nd表示的实际雪的深度,wd表示鞋子可以踏的最大深度,s表示的最大距离,dp表示在第j个位置穿最少的鞋数
int main(){
	cin>>n>>b;
	for(ll i=1;i<=n;i++)
		cin>>nd[i];
	for(ll i=1;i<=b;i++)
		cin>>wd[i]>>s[i];
	for(ll i=2;i<=n; i++)
		dp[i]=inf;
	dp[1]=1;
	for(ll i=2;i<=n;i++){
		for(ll j=i-1;j>=1;j--){
			for(ll k=dp[j];k<=b;k++){
				if(wd[k]>=nd[j]&&wd[k]>=nd[i]&&i-j<=s[k])
					dp[i]=min(dp[i],k);
			}
		}
	}
	cout<<(dp[n]-1)<<endl;
	return 0;
}
全部评论

相关推荐

评论
点赞
收藏
分享

创作者周榜

更多
正在热议
更多
# 长得好看会提高面试通过率吗? #
4471次浏览 48人参与
# 离家近房租贵VS离家远但房租低,怎么选 #
16917次浏览 137人参与
# MiniMax求职进展汇总 #
25260次浏览 322人参与
# 沪漂/北漂你觉得哪个更苦? #
1616次浏览 41人参与
# 你的实习产出是真实的还是包装的? #
3230次浏览 54人参与
# 春招至今,你的战绩如何? #
16140次浏览 146人参与
# 米连集团26产品管培生项目 #
7384次浏览 226人参与
# HR最不可信的一句话是__ #
1107次浏览 32人参与
# AI面会问哪些问题? #
971次浏览 24人参与
# 你做过最难的笔试是哪家公司 #
1306次浏览 23人参与
# AI时代,哪个岗位还有“活路” #
2930次浏览 53人参与
# 不考虑薪资和职业,你最想做什么工作呢? #
152945次浏览 889人参与
# 简历第一个项目做什么 #
32180次浏览 363人参与
# 军工所铁饭碗 vs 互联网高薪资,你会选谁 #
8029次浏览 43人参与
# XX请雇我工作 #
51164次浏览 171人参与
# 简历中的项目经历要怎么写? #
311119次浏览 4271人参与
# 投格力的你,拿到offer了吗? #
178382次浏览 891人参与
# 你最满意的offer薪资是哪家公司? #
77008次浏览 375人参与
# AI时代,哪些岗位最容易被淘汰 #
64819次浏览 891人参与
# 当下环境,你会继续卷互联网,还是看其他行业机会 #
187635次浏览 1123人参与
# 你怎么看待AI面试 #
180882次浏览 1318人参与
# 正在春招的你,也参与了去年秋招吗? #
364407次浏览 2642人参与
牛客网
牛客网在线编程
牛客网题解
牛客企业服务