数字三角形-动态规划-无

简介: 数字三角形-动态规划-无


数字三角形(POJ1163)

在上面的数字三角形中寻找一条从顶部到底边的路径,使得

路径上所经过的数字之和最大。路径上的每一步都只能往左下或

右下走。只需要求出这个最大和即可,不必给出具体路径。

三角形的行数大于1小于等于100,数字为 0 - 99

7

3 8

8 1 0

2 7 4 4

4 5 2 6 5

解题思路:

用二维数组存放数字三角形。

D( r, j) : 第r行第 j 个数字(r,j从1开始算)

MaxSum(r, j) : 从D(r,j)到底边的各条路径中,

最佳路径的数字之和。

问题:求 MaxSum(1,1)

典型的递归问题。

D(r, j)出发,下一步只能走D(r+1,j)或者D(r+1, j+1)。故对于N行的三角形:

if ( r == N)

MaxSum(r,j) = D(r,j)

else

MaxSum( r, j) = Max{ MaxSum(r+1,j), MaxSum(r+1,j+1) } + D(r,j)。、

#include<stdio.h>
#include<algorithm>
using namespace std;
int n;
int a[101][101];
int m[101][101];
int maxsum(int i,int j)
{
  if(m[i][j]!=-1)
  {
    return m[i][j];
  }
  if(n==i)
  {
    return a[i][j];
  }
  int x=maxsum(i+1,j);
  int y=maxsum(i+1,j+1);
  return m[i][j]=max(x,y)+a[i][j];
}
int main()
{
  scanf("%d",&n);
  for(int i=1;i<=n;i++)
  {
    for(int j=1;j<=i;j++)
    {
      scanf("%d",&a[i][j]);
      m[i][j]=-1;
    }
  }
  printf("%d",maxsum(1,1));
return 0;
}


相关文章
|
算法 JavaScript 前端开发
编码之舞:我的技术感悟之旅
在编程的世界里,代码不仅仅是冷冰冰的文字排列,它们更像是一种艺术的表达。本文通过个人的技术成长经历,探讨如何将编程转化为一种创造性的活动,以及在技术探索中如何找到乐趣和成就感。文章旨在分享从初学者到资深开发者的转变过程中的心得体会,鼓励读者以积极的心态面对技术挑战,享受编程带来的乐趣。
|
人工智能 Kubernetes 小程序
开发者社区精选直播合集(二十七)| HaaS物联网最佳实践
HaaS(Hardware as a Service)物联网设备云端一体开发框架,整合阿里云、达摩院、平头哥技术,基于数亿物联网设备接入经验,提供积木式硬件开发能力,实现低代码快速开发,帮助中小开发者聚焦业务,实现设备安全上云,加速设备创新迭代。
开发者社区精选直播合集(二十七)| HaaS物联网最佳实践
|
Linux 弹性计算 数据库
基于阿里云产品的服务器演进-单机
公司创办初期,基于成本,以及用户访问量的因素,需要选择合适的云产品搭建应用。本文基于阿里云现有云产品进行分析,提供合理的选型建议。
481 0
基于阿里云产品的服务器演进-单机
|
23小时前
|
人工智能 运维 安全
|
3天前
|
SpringCloudAlibaba 负载均衡 Dubbo
微服务架构下Feign和Dubbo的性能大比拼,到底鹿死谁手?
本文对比分析了SpringCloudAlibaba框架下Feign与Dubbo的服务调用性能及差异。Feign基于HTTP协议,使用简单,适合轻量级微服务架构;Dubbo采用RPC通信,性能更优,支持丰富的服务治理功能。通过实际测试,Dubbo在调用性能、负载均衡和服务发现方面表现更出色。两者各有适用场景,可根据项目需求灵活选择。
362 123
微服务架构下Feign和Dubbo的性能大比拼,到底鹿死谁手?
|
6天前
|
人工智能 JavaScript 测试技术
Qwen3-Coder入门教程|10分钟搞定安装配置
Qwen3-Coder 挑战赛简介:无论你是编程小白还是办公达人,都能通过本教程快速上手 Qwen-Code CLI,利用 AI 轻松实现代码编写、文档处理等任务。内容涵盖 API 配置、CLI 安装及多种实用案例,助你提升效率,体验智能编码的乐趣。
531 107
|
2天前
|
Java 数据库 数据安全/隐私保护
Spring 微服务和多租户:处理多个客户端
本文介绍了如何在 Spring Boot 微服务架构中实现多租户。多租户允许单个应用实例为多个客户提供独立服务,尤其适用于 SaaS 应用。文章探讨了多租户的类型、优势与挑战,并详细说明了如何通过 Spring Boot 的灵活配置实现租户隔离、动态租户管理及数据源路由,同时确保数据安全与系统可扩展性。结合微服务的优势,开发者可以构建高效、可维护的多租户系统。
187 127

热门文章

最新文章