热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

数塔问题的C语言与C++动态规划求解算法详解

本文详细介绍了使用C语言和C++实现的动态规划算法来解决数塔问题。通过具体的代码示例和算法解析,展示了如何高效地计算数塔的最大路径和。该方法不仅适用于数塔问题,还可应用于其他类似的组合优化问题。

/*

* File name : digital_tower.cpp

* Function : 动态规划 数塔问题求解 C++实现

* Created on : 2016年6月17日

* Author : beijiwei@qq.com

* Copyright : 欢迎大家和我一起交流学习,转载请保持源文件的完整性。

任何单位和个人不经本人允许不得用于商业用途

9

12 15

10 6 8

2 18 9 5

19 7 10 4 16

从顶层或底层 走,在每一节点可选择左走或者右走.

求一条路径,使得到的数值和最大.

input:

9

12 15

10 6 8

2 18 9 5

19 7 10 4 16

*/

#include

#include

#pragma warning(disable:4996)

using namespace std;

#define M 5

int get_max(int x, int y);

int main(int argc, char** argv)

{

int i = 0, j = 0, k = 0;

int map[M][M];

int result[M][M];

freopen("input.txt", "r", stdin);

memset(result, 0, sizeof(int)*M*M);

memset(map, 0, sizeof(int)*M*M);

for (i = 0; i

{

for (j = 0; j

{

cin >> map[i][j];

if (i == M - 1)

{

result[i][j] = map[i][j];

}

}

}

for (k = M - 2; k >= 0; k--)//上塔 第k层,

{

for (i = 0; i

{

result[k][i] = get_max(map[k][i] + result[k + 1][i], map[k][i] + result[k + 1][i+1]);

}

}

cout <

int target &#61; result[0][0] - map[0][0];

cout <

i &#61; 1;

while ( i

{

for (j &#61; 0; j

{

if (result[i][j] &#61;&#61; target)

{

target &#61; result[i][j] - map[i][j];

cout <

break;

}

}

i&#43;&#43;;

}

cout <

return 0;

}

int get_max(int x, int y)

{

return (x > y) ? x : y;

}



推荐阅读
  • 编译原理中的语法分析方法探讨
    本文探讨了在编译原理课程中遇到的复杂文法问题,特别是当使用SLR(1)文法时遇到的多重规约与移进冲突。文章讨论了可能的解决策略,包括递归下降解析、运算符优先级解析等,并提供了相关示例。 ... [详细]
  • c语言二元插值,二维线性插值c语言
    c语言二元插值,二维线性插值c语言 ... [详细]
  • 本文通过C++语言实现了一个递归算法,用于解析并计算数学表达式的值。该算法能够处理加法、减法、乘法和除法操作。 ... [详细]
  • 实现系统调用
    实现系统调用一、实验环境​本次操作还是基于上次编译Linux0.11内核的实验环境进行操作。环境如下:二、实验目标​通过对上述实验原理的认识,相信 ... [详细]
  • 本文详细介绍了在单片机编程中常用的几个C库函数,包括printf、memset、memcpy、strcpy和atoi,并提供了具体的使用示例和注意事项。 ... [详细]
  • 本文详细介绍了Oracle 11g中的创建表空间的方法,以及如何设置客户端和服务端的基本配置,包括用户管理、环境变量配置等。 ... [详细]
  • Maven + Spring + MyBatis + MySQL 环境搭建与实例解析
    本文详细介绍如何使用MySQL数据库进行环境搭建,包括创建数据库表并插入示例数据。随后,逐步指导如何配置Maven项目,整合Spring框架与MyBatis,实现高效的数据访问。 ... [详细]
  • Java 中的十进制样式 getZeroDigit()方法,示例 ... [详细]
  • 问题描述现在,不管开发一个多大的系统(至少我现在的部门是这样的),都会带一个日志功能;在实际开发过程中 ... [详细]
  • AI炼金术:KNN分类器的构建与应用
    本文介绍了如何使用Python及其相关库(如NumPy、scikit-learn和matplotlib)构建KNN分类器模型。通过详细的数据准备、模型训练及新样本预测的过程,展示KNN算法的实际操作步骤。 ... [详细]
  • Web动态服务器Python基本实现
    Web动态服务器Python基本实现 ... [详细]
  • PHP面试题精选及答案解析
    本文精选了新浪PHP笔试题及最新的PHP面试题,并提供了详细的答案解析,帮助求职者更好地准备PHP相关的面试。 ... [详细]
  • C语言中的指针详解
    1.什么是指针C语言中指针是一种数据类型,指针是存放数据的内存单元地址。计算机系统的内存拥有大量的存储单元,每个存储单元的大小为1字节, ... [详细]
  • 电商高并发解决方案详解
    本文以京东为例,详细探讨了电商中常见的高并发解决方案,包括多级缓存和Nginx限流技术,旨在帮助读者更好地理解和应用这些技术。 ... [详细]
  • C语言中的结构体详解
    本文详细介绍了C语言中的结构体,包括结构体的声明、初始化、成员访问以及传参等方面的知识。 ... [详细]
author-avatar
白猫警员123
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有