zoukankan      html  css  js  c++  java
  • 寻宝路线(动态规划)


    #include <stdio.h>
    #define MAX 101
    int map[MAX][MAX];
    int S[MAX][MAX];
    int F[MAX][MAX];
    
    int m, n;
    int max(int a, int b)
    {
    	return a > b ? a : b;
    }
    int dp(int i, int j)
    {
    	if (i < 0 || j < 0)	return -10000;
    	if (F[i][j])	return F[i][j]; // F[i][j]存放的就是从右下角到达该点捡起宝物价值最大值,最后F[0][0]即为所求
    	if (i == m - 1 && j == n - 1)//ij条件交集放前面 
    	{
    		return F[i][j] = map[i][j];
    	}
    	else if (i == m - 1) // 到达底端,就只能往右走
    	{
    		return F[i][j] = map[i][j] + dp(i, j + 1);
    	}
    	else if (j == n - 1) // 到达右端,只能往下走
    	{
    		return F[i][j] = map[i][j] + dp(i + 1, j);
    	}
    	else // 否则在这一点能够获得的最大价值就是该点的宝物价值加上往右或者往下走能够获得的最大价值
    	{
    		return F[i][j] = map[i][j] + max(dp(i + 1, j), dp(i, j + 1));
    	}
    }
    
    int s(int i, int j)
    {
    	if (i < 0 || j < 0)	return -10000;
    	if (S[i][j])	return S[i][j];
    	if (i == m - 1 || j == n - 1)//到边界,只能往右或者往下,只有唯一路径,不用继续走了 
    	{
    		return S[i][j] = 1;
    	}
    	else
    	{
    		if (F[i][j] == map[i][j] + F[i][j + 1])	S[i][j] += s(i, j + 1);
    		if (F[i][j] == map[i][j] + F[i + 1][j])	S[i][j] += s(i + 1, j);
    		return S[i][j];
    	}
    }
    
    int main()
    {
    	int i, j;
    	scanf("%d %d", &m, &n);
    	for (i = 0; i < m; ++i)
    	{
    		for (j = 0; j < n; ++j)
    		{
    			scanf("%d", &map[i][j]);
    		}
    	}
    	printf("%d ", dp(0, 0));
    
      /*putchar('
    ');
    	putchar('
    ');
    	printf("便于理解,打印F数组,记录最值:
    ");
    	for (i = 0; i < m; ++i)
    	{
    		for (j = 0; j < n; ++j)
    		{
    			printf("%d ", F[i][j]);
    		}
    		putchar('
    ');
    	}
    	putchar('
    ');
    	putchar('
    ');*/
    
    	printf("%d
    ",s(0,0));
    
    	/*putchar('
    ');
    	putchar('
    ');
    	printf("便于理解,打印S数组,记录路径最大值:
    ");
    	for (i = 0; i < m; ++i)
    	{
    		for (j = 0; j < n; ++j)
    		{
    			printf("%d ", S[i][j]);
    		}
    		putchar('
    ');
    	}*/
    
    	return 0;
    }
    相似的题目,贪心加动态规划,见我另一篇博客点击打开链接

    ========================================Talk is cheap, show me the code=======================================

    CSDN博客地址:https://blog.csdn.net/qq_34115899
  • 相关阅读:
    v-for
    class样式绑定
    数据单向绑定(v-bind:)和数据的双向绑定(v-model)
    v-on 事件修饰符
    C++中相对路径与绝对路径以及斜杠与反斜杠的区别(转)
    计算机图形学—判断点在直线上的方法(转)
    Eclipse XML/HTML语法高亮方法
    虚拟机 ubuntu 上网的配置过程
    VirtualBox虚拟机网络设置(四种方式)(转)
    查看Linux服务器网络状态(转)
  • 原文地址:https://www.cnblogs.com/lcy0515/p/9179800.html
Copyright © 2011-2022 走看看