当前位置:文档之家› 动态规划教案

动态规划教案

教法: 1.多媒体讲解 2.举例讲解
教学内容及过程: 1. 课前回顾:
枚举法: 在进行归纳推理时,如果逐个考察了某类事件的所有可能情况,因而得出一般
结论,那么这结论是可靠的,这种归纳方法叫做枚举法.
2. 数塔问题 有形如下图所示的数塔,从顶部出发,在每一结点可以选择向左走或是向右
走,一直走到底层,要求找出一条路径,使路径上的值最大。
cin>>y>>x; a[x][y]++; if(x>f)
f=x; } for(i=f-1;i>=0;i--) {
for(j=0;j<11;j++) if(j>0&&j<10) a[i][j]+=max(a[i+1][j-1],a[i+1][j],a[i+1][j+1]); else if(j==0) a[i][j]+=max(0,a[i+1][j],a[i+1][j+1]); else a[i][j]+=max(0,a[i+1][j-1],a[i+1][j]);
都说天上不会掉馅饼,但有一天 gameboy 正走在回家的小径上,忽然天上掉下大把大把的 馅饼。说来 gameboy 的人品实在是太好了,这馅饼别处都不掉,就掉落在他身旁的 10 米 范围内。馅饼如果掉在了地上当然就不能吃了,所以 gameboy 马上卸下身上的背包去接。 但由于小径两侧都不能站人,所以他只能在小径上接。由于 gameboy 平时老呆在房间里玩 游戏,虽然在游戏中是个身手敏捷的高手,但在现实中运动神经特别迟钝,每秒种只有在移 动不超过一米的范围内接住坠落的馅饼。现在给这条小径如图标上坐标:
为了使问题简化,假设在接下来的一段时间里,馅饼都掉落在 0-10 这 11 个位置。开始时 gameboy 站在 5 这个位置,因此在第一秒,他只能接到 4,5,6 这三个位置中期中一个位置 上的馅饼。问 gameboy 最多可能接到多少个馅饼?(假设他的背包可以容纳无穷多个馅饼)
#include<iostream> using namespace std; int a[100001][11]; int max(int x,int y,int z) {
} cout<<a[0][5]<<endl; } //system("PAUSE");
return 0;
}
7.课后作业 杭电 ACM 1003 、 1466 、1087、1159、1176 、1058、1069、2059、2084
吉林师范大学计算机学院
教案
课 程 名 称 C 程序设计(算法部分)


级 计算机学院计算机科学与技术 09 级
教研室(系、实验室) 计算机基础教研室 5101
授 课 班 级 09 计算机科学与技术 3 班


生 郑言
系 指 导 教 师 滕国文
吉林师范大学计算机学院
二○一二年四月二十五日(星期三 5,6 节)
其中(1)——(3)步是动态规划算法的基本步骤。在只需要求出最优值的情形, 步骤(4)可以省去。若需要求出问题的一个最优解,则必须执行步骤(4)。此时,在步骤 (3)中计算最优值时,通常需记录更多的信息,以便在步骤(4)中,根据所记录的信息, 快速构造出一个最优解。 5.总结“动态规划问题的特征” 动态规划算法的有效性依赖于问题本身所具有的两个重要性质:
简单的进行选举方法的引导,让同学们主动思考到动态规划的思想上了。 考虑一下:
从顶点出发时到底向左走还是向右走应取决于是从左走能取到最大值还 是从右走能取到最大值,只要左右两道路径上的最大值求出来了才能作出决 策。
同样,下一层的走向又要取决于再下一层上的最大值是否已经求出才能 决策。这样一层一层推下去,直到倒数第二层时就非常明了。
掌握 C 语言中动态规划的基本概念,动态规划的基本步骤,动态规划问题的特征。 并能熟练使用 C 语言动态规划思想解决一些简单程序问题;掌握一些基本算法结 构及相关方法;熟悉程序设计的思想和编程技巧。 重点:
动态规划基本概念,动态规划的基本步骤,动态规划问题的特征。 难点:
动态规划的基本步骤
课型: 理论课
else return y;
} main() {
int a[100][100]; int i,j,n; scanf("%d",&n); for(i=0;i<n;i++)
for(j=0;j<=i;j++) scanf("%d",&a[i][j]);
for(i=n-2;i>=0;i--) for(j=0;j<=i;j++) { a[i][j]+=max(a[i+1][j],a[i+1][j+1]); }
如数字 2,只要选择它下面较大值的结点 19 前进就可以了。所以实际求 解时,可从底层开始,层层递进,最后得到最大值。
结论:自顶向下的分析,自底向上的计算。 #include<stdio.h> #include<math.h> int max(int x,int y) {
if(x>y) return x;
课型章节: 动态规划基本思想
基要本参教考材资和料主: 算法设计与分析》
教学目的: 本课程以 C 语言为教授程序设计的描述语言,结合语言介绍程序设计的基本
原理、技巧和方法。主要讲授内容包括程序设计动态规划基本概念,动态规划的 基本步骤,动态规划问题的特征。通过本课程的学习,为算法更好的学习,以及能 用计算机解决一些实际问题打下坚实的基础。 教学基本要求:
动态规划算法通常用于求解具有某种最优性质的问题。在这类问题中,可能会有许多可行解。
每一个解都对应于一个值,我们希望找到具有最优值(最大值或最小值)的那个解。设计一
个动态规划算法,通常可以按以下几个步骤进行: (1)找出最优解的性质,并刻画其结构特征。 (2)递归地定义最优值。 (3)以自底向上的方式计算出最优值。 (4)根据计算最优值时得到的信息,构造一个最优解。
if(x>y) if(x>z) return x;
else return z;
else if(y>z) return y; else return z;
} int main() {
int i,j,f,n,x,y; while(cin>>n) {
if(n==0) break;
memseቤተ መጻሕፍቲ ባይዱ(a,0,sizeof(a)); f=0; for(i=0;i<n;i++) {
1、最优子结构:当问题的最优解包含了其子问题的最优解时,称该问题具有最优 子结构性质。
2、重叠子问题:在用递归算法自顶向下解问题时,每次产生的子问题并不总是新 问题,有些子问题被反复计算多次。动态规划算法正是利用了这种子问题的重叠性质,对每 一个子问题只解一次,而后将其解保存在一个表格中,在以后尽可能多地利用这些子问题的 解。 6.思考: 《免费馅饼》 题目描述:
printf("%d\n",a[0][0]); } 3.总结“动态规划的基本思想” 如果各个子问题不是独立的,不同的子问题的个数只是多项式量级,如果我 们能够保存已经解决的子问题的答案,而在需要的时候再找出已求得的答案,这 样就可以避免大量的重复计算。由此而来的基本思路是,用一个表记录所有已解 决的子问题的答案,不管该问题以后是否被用到,只要它被计算过,就将其结果 填入表中。 4.总结“动态规划的基本步骤”
相关主题