【蓝桥杯冲冲冲】动态规划初步[USACO2006 OPEN] 县集市

这篇具有很好参考价值的文章主要介绍了【蓝桥杯冲冲冲】动态规划初步[USACO2006 OPEN] 县集市。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

蓝桥杯备赛 | 洛谷做题打卡day13

  • [USACO2006 OPEN] 县集市 The County Fair

    题目描述

    每年,FJ 都喜欢去参加县集市,集市上有 n n n 个展位,每个摊位 i i i 都会在当天的特定时间 p i p_i pi 发放精美的礼品。FJ 已经听说了这一点,他希望能收集尽可能多的礼品和他的奶牛们一起分享。要想获得摊位 i i i 发放的礼品,FJ 必须确保时间点 p i p_i pi 时位于摊位 i i i

    为了获得尽可能多的礼品,FJ 进行了一番详细的调查,通过调查FJ确定了从摊位 i i i 到摊位 j j j 所花费的时间 t i , j t_{i,j} ti,j。集市的布局很不寻常,这会导致,FJ如果在从 i i i j j j 的过程中选择从其他摊位绕行,可能会比直接从 i i i j j j 所花费的时间更少,然而我们耿直的 FJ 从来不这么做,如果他想从摊位 i i i 到摊位 j j j,他一定会花 t i , j t_{i,j} ti,j 的时间从 i i i 走到 j j j。另外由于集市所在地崎岖不平,所以 t i , j t_{i,j} ti,j 可能与 t j , i t_{j,i} tj,i 不相同。

    FJ 在时间 0 0 0 时,位于 1 1 1 号摊位,请计算他最多可以收集多少奖品。

    输入格式

    1 1 1 行:一个整数 n n n,表示摊位的数量。

    2 2 2 行:共 n n n 个整数,其中第 i + 1 i+1 i+1 的正数 p i p_i pi 表示摊位 i i i 发放礼品的时间。

    n + 2 n+2 n+2 到第 n 2 + n + 1 n^2+n+1 n2+n+1 行:共 n 2 n^2 n2 行,第一个 n n n 行描述了 FJ 从摊位 1 1 1 走到到摊位 1 1 1 n n n 所需时间( t 1 , 1 , t 1 , 2 , . . . t 1 , n t_{1,1},t_{1,2}, ...t_{1,n} t1,1,t1,2,...t1,n),接下来的 n n n 行描述了 FJ 从摊位 2 2 2 走到摊位 1 1 1 n n n 所需时间( t 2 , 1 , t 2 , 2 , . . . t 2 , n t_{2,1},t_{2,2}, ...t_{2,n} t2,1,t2,2,...t2,n),以此类推,最后的 n n n 行描述了 FJ 从摊位 n n n 走到摊位 1 1 1 n n n 所需要的时间 t n , 1 , t n , 2 , . . . t n , n t_{n,1},t_{n,2}, ...t_{n,n} tn,1,tn,2,...tn,n。对于任意摊位 i i i t i , i = 0 t_{i,i}=0 ti,i=0

    输出格式

    一行:一个整数,表示 FJ 最多可以领取到的奖品数量。

    样例 #1

    样例输入 #1

    4
    13
    9
    19
    3
    0
    10
    20
    3
    4
    0
    11
    2
    1
    15
    0
    12
    5
    5
    13
    0
    

    样例输出 #1

    3
    

    提示

    样例说明

    样例中集市上共有 4 4 4 个摊位。 1 1 1 号摊位在时间 13 13 13 发放礼品, 2 2 2 号摊位在时间 9 9 9 发放礼品, 3 3 3 号摊位在时间 19 19 19 发放礼品, 4 4 4 号摊位在时间 3 3 3 发放礼品。

    FJ 首先从 1 1 1 号摊位走到 4 4 4 号摊位,用时 3 3 3,并在时间 3 3 3 到达,正好可以领取到奖品,接着他从摊位 4 4 4 走到摊位 2 2 2 ,用时 5 5 5,并在时间 8 8 8 到达,在等待 1 1 1 个时间点后可以领取 2 2 2 号摊位的礼品,接着他从 2 2 2 号摊位走到 1 1 1 号摊位,用时 4 4 4,并在时间 13 13 13 到达,从而可以收集到第 3 3 3 个礼品。

    数据规模与约定

    对于 100 % 100\% 100% 的数据, 1 ≤ n ≤ 400 1\le n\le 400 1n400 0 ≤ p i ≤ 1 0 9 0\le p_i\le 10^9 0pi109 1 ≤ t i , j ≤ 1 0 6 1\le t_{i,j}\le 10^6 1ti,j106


思路:

这道题目我们可以用动态规划做。我们先对时间顺序排序,时间小的在前面,因为只有先经过小的时间才可以推算大的时间。接着我们就有了一个数组,用来记录在前 *i* 个礼物中最多能拿几个礼物,且第 *i* 个礼物一定要取。当然这个要经过前面的推算才能得出。

方程:

我们需要通过前面的时间推算那么我们就可以做一个判断:如果前面那个礼物发放的时间加上那个集市到这个集市的时间小于等于这个礼物发放的时间,那么就可以从那个集市过来,之所以是要一定小于等于,是因为这个礼物必须要取。通过所有可以到达的集市,更新数组的最大值。

【蓝桥杯冲冲冲】动态规划初步[USACO2006 OPEN] 县集市,C++知识,蓝桥杯备赛,新手帖,蓝桥杯,动态规划,职场和发展

题解代码

学会利用新知,自己多试试并尝试积攒一些固定解答方案,debug,以下是题解代码 ~

#include <bits/stdc++.h>
using namespace std;
struct o//每一个集市的信息,下面的t和b分别是发放礼物的时间和集市的编号,记录编号是因为下面的排序有可能打乱编号
{
	int t;
	int b;
};
int p(o o1,o o2)//定义排序的优先级,发放礼物时间前的集市在前面
{
	return o1.t<o2.t;
}
int dp[401],ans;//把它们放在外面,自动清零
int main()
{
	o s[401];//定义所有的集市
	int n,t[401][401];//集市数量和走这两个集市的路的时间
	scanf("%d",&n);
	for(int i=1;i<=n;i++)
	{
		scanf("%d",&s[i].t);
		s[i].b=i;
	}
	for(int i=1;i<=n;i++)
		for(int j=1;j<=n;j++)
			scanf("%d",&t[i][j]);
	sort(s+1,s+n+1,p);
	s[0].b=1,s[0].t=0;//赋初始值,在第0分钟,FJ在第一个集市
	for(int i=1;i<=n;i++)
		for(int j=0;j<i;j++)
			if(t[s[j].b][s[i].b]+s[j].t<=s[i].t)
				dp[i]=max(dp[j]+1,dp[i]),ans=max(ans,dp[i]);//通过方程更新最大值
	printf("%d",ans);
	return 0;
}

我的一些话

  • 前几天一直在学习图论算法,今天看看动态规划算法初步吧,动态规划dp有一定难度,需要通盘的考虑和理解,以及扎实的数据结构基础才能独立写出AC代码。但无论难易,大家都要持续做题,保持题感喔!一起坚持(o´ω`o)

  • 如果有非计算机专业的uu自学的话,关于数据结构的网课推荐看b站上青岛大学王卓老师的课,讲的很细致,有不懂都可以私信我喔

  • 总结来说思路很重要,多想想,多在草稿纸上画画,用测试数据多调试,debug后成功编译并运行出正确结果真的会感到很幸福!

  • 关于之前蓝桥杯备赛的路线和基本方法、要掌握的知识,之前的博文我都有写,欢迎大家关注我,翻阅自取哦~

  • 不管什么都要坚持吧,三天打鱼两天晒网无法形成肌肉记忆和做题思维,该思考的时候一定不要懈怠,今天就说这么多啦,欢迎评论留言,一起成长:)文章来源地址https://www.toymoban.com/news/detail-814064.html

到了这里,关于【蓝桥杯冲冲冲】动态规划初步[USACO2006 OPEN] 县集市的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 【蓝桥杯-筑基篇】动态规划

    🍓系列专栏:蓝桥杯 🍉个人主页:个人主页 目录 1.最大连续子段和 2.LCS 最大公共子序列 3.LIS 最长上升子序列 4.数塔 5.最大子矩阵和 6.背包问题 ①01背包问题 ②完全背包 这段代码是一个求最大子数组和的算法,使用的是动态规划的思想。下面是代码的解释: 首先定义了一个

    2023年04月24日
    浏览(71)
  • 【蓝桥杯/动态规划】数的计算

    题目描述 输入一个自然数 n (n≤1000)n (n leq 1000) n   ( n ≤ 1 0 0 0 ) ,我们对此自然数按照如下方法进行处理: 不作任何处理; 在它的左边加上一个自然数,但该自然数不能超过原数的一半; 加上数后,继续按此规则进行处理,直到不能再加自然数为止。 问总共可以产生多少个数。

    2024年02月01日
    浏览(47)
  • 蓝桥杯动态规划基础篇(一)

    动态规划(Dynamic Programming,DP)是运筹学的一个分支,是求解决策过程最优化的过程。20世纪50年代初,美国数学家贝尔曼(R.Bellman)等人在研究多阶段决策过程的优化问题时,提出了著名的最优化原理,从而创立了动态规划。动态规划的应用极其广泛,包括工程技术、经济、

    2024年02月03日
    浏览(37)
  • 蓝桥杯(路径 动态规划 C++)

     思路: 1、利用动态规划的思想。 2、用f[i]来记录从第一个点到第i个点的最短距离。 3、f[i]赋值分两种情况,第一种:f[i]为0的时候,也就是第一种刚到i点的情况,记录其距离为最小公倍数;第二种:f[i]已经有值了,比较新的点到其距离和之前点到其距离,取小的赋值。

    2024年02月07日
    浏览(35)
  • 蓝桥杯-动态规划-子数组问题

    目录 一、乘积最大数组 二、乘积为正数的最长子数组长度 三、等差数列划分 四、最长湍流子数组 心得: 最重要的还是状态表示,我们需要根据题的意思,来分析出不同的题,不同的情况,来分析需要多少个状态 乘积最大数组 1.状态表示 dp[i]:到达i位置的最大乘积子数组。

    2024年02月05日
    浏览(34)
  • 蓝桥:保险箱(Python,动态规划)

    小蓝有一个保险箱,保险箱上共有 n 位数字。小蓝可以任意调整保险箱上的每个数字,每一次操作可以将其中一位增加 1 或减少 1。当某位原本为 9 或 0 时可能会向前(左边)进位/退位,当最高位(左边第一位)上的数字变化时向前的进位或退位忽略。 例如: 00000 的第 5 位减

    2024年04月09日
    浏览(90)
  • 蓝桥杯-回路计数(状态压缩、动态规划)

    蓝桥学院由 21 21 21 栋教学楼组成,教学楼编号 11 11 11 ​​ 到 21 21 21 ​​。对于两栋教学楼 a a a 和 b b b ​,当 a a a 和 b b b 互质时, a a a 和 b b b 之间有一条走廊直接相连,两个方向皆可通行,否则没有直接连接的走廊。 小蓝现在在第一栋教学楼,他想要访问每栋教学楼正

    2024年02月08日
    浏览(58)
  • 动态规划树形DP课后习题蓝桥舞会

      蓝桥舞会 题目描述 蓝桥公司一共有n名员工,编号分别为1~n。 他们之间的关系就像一棵以董事长为根的树,父节点就是子节点的直接上司。每个员工有一个快乐指数aj。 现蓝桥董事会决定举办一场蓝桥舞会来让员工们在工作之余享受美好时光,不过对于每个员工,他们都

    2024年02月21日
    浏览(43)
  • JAVA蓝桥杯备考---6.动态规划(一)

    动态规划简称 DP,通过把原问题分解为相对简单的子问题的方式求解复杂问题的方法。动态规划常常适用于有重叠子问题和最优子结构性质的问题。 简单来说,动态规划其实就是,给定一个问题,我们把它拆成一个个子问题,直到子问题可以直接解决然后呢,把子问题答案保

    2024年02月19日
    浏览(32)
  • 蓝桥杯:最优包含--动态规划(C语言)

    1、S串用i进行遍历,T串用j进行遍历。 2、dp数组[i][j]的含义:S串中从S[0]到S[i],最少修改dp[i][j]个字符,可以包含T串中从T[0]到T[j]这部分字符串。 3、遍历时遇到的情况有两种: (1)情况一:S[i]==T[j]        dp[i][j]=min(dp[i-1][j],dp[i-1][j-1]);        dp[i-1][j]的含义:S[0]到S[i-1]中

    2024年02月16日
    浏览(38)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包