解题思路:

该题是一道经典的动态规划,对于这样的数字三角形,
我们用一个数组arr存储各个位置的数字,再用另一个数组brr来记录到该位置的最大路径

对于图中的7,我们用数组保存就是arr[0][0]
对于图中的8,也就是arr[1][1]
情况1:走到最左边一列

这种情况只可能是上一行最左边一列走过来的,如图
以上图为例:
我们brr现在开始从起点7出发,因为起点只有一个,也就是把arr的值7赋给brr[0][0]
然后假设我们从7往左走到3,也就是arr[0][0]走向arr[1][0],我们可以记录brr[1][0]=brr[0][0]+arr[1][0]
对于其他的路径走到最左边一列,那都是brr[i][0] = brr[i - 1][0]+ arr[i][0],
brr[i - 1][0]是之前走过的最大长度,arr[i][0]是当前节点的长度
情况2:走到中间列

假设现在走到了1,1是有两条路可以走过来的,一个是3过来的,一个是8过来的。
我们brr是要到这1这个节点的最大值啊,所以需要对3过来的路和8过来的路大小进行比较
对应到arr数组中就是brr[2][1]=max(brr[1][0],brr[1][1])+arr[2][1]
推广开来就是 brr[i][j] = max(brr[i - 1][j - 1], brr[i - 1][j]) + arr[i][j]
情况3:走到最右边一列
这种和情况1类似,只能有上一行最右边走过来

推广公式为brr[i][j] = brr[i - 1][j - 1] + arr[i][j]
代码如下:
```c
#include <stdio.h>
#include <stdlib.h>
int max(int x,int y)
{
return x>y?x:y;
}
int main(int argc, char *argv[])
{
// 请在此输入您的代码
int arr[100][100];
int brr[100][100];
int n = 0;
int i = 0;
int j = 0;
scanf("%d", &n);
for (i = 0;i < n;i++)
{
for (j = 0;j <= i;j++)
{
scanf("%d", &arr[i][j]);
}
}
brr[0][0] = arr[0][0];
for (i = 1;i < n;i++)
{
for (j = 0;j <= i;j++)
{
if (j == 0)//第一列的情况
{
brr[i][j] = brr[i - 1][j]+ arr[i][j];
}
else if (j != 0 && j != i)//中间列的情况
{
brr[i][j] = max(brr[i - 1][j - 1], brr[i - 1][j]) + arr[i][j];
}
else//最后一列的情况
{
brr[i][j] = brr[i - 1][j - 1] + arr[i][j];
}
}
}
if (n % 2 != 0) //如果行数是奇数,最后会走到最后一行中间的数
{
printf("%d", brr[n - 1][(n - 1) / 2]);
}
else {//如果行数是偶数,最后取中间两个较大值即可
printf("%d", max(brr[n - 1][(n - 1) / 2], brr[n - 1][n / 2]));
}
return 0;
}

我正在寻找执行以下操作的正确语法(在Perl、Shell或Ruby中):#variabletoaccessthedatalinesappendedasafileEND_OF_SCRIPT_MARKERrawdatastartshereanditcontinues. 最佳答案 Perl用__DATA__做这个:#!/usr/bin/perlusestrict;usewarnings;while(){print;}__DATA__Texttoprintgoeshere 关于ruby-如何将脚
几个月前,我读了一篇关于rubygem的博客文章,它可以通过阅读代码本身来确定编程语言。对于我的生活,我不记得博客或gem的名称。谷歌搜索“ruby编程语言猜测”及其变体也无济于事。有人碰巧知道相关gem的名称吗? 最佳答案 是这个吗:http://github.com/chrislo/sourceclassifier/tree/master 关于ruby-寻找通过阅读代码确定编程语言的rubygem?,我们在StackOverflow上找到一个类似的问题:
我正在尝试解析一个CSV文件并使用SQL命令自动为其创建一个表。CSV中的第一行给出了列标题。但我需要推断每个列的类型。Ruby中是否有任何函数可以找到每个字段中内容的类型。例如,CSV行:"12012","Test","1233.22","12:21:22","10/10/2009"应该产生像这样的类型['integer','string','float','time','date']谢谢! 最佳答案 require'time'defto_something(str)if(num=Integer(str)rescueFloat(s
目录一.加解密算法数字签名对称加密DES(DataEncryptionStandard)3DES(TripleDES)AES(AdvancedEncryptionStandard)RSA加密法DSA(DigitalSignatureAlgorithm)ECC(EllipticCurvesCryptography)非对称加密签名与加密过程非对称加密的应用对称加密与非对称加密的结合二.数字证书图解一.加解密算法加密简单而言就是通过一种算法将明文信息转换成密文信息,信息的的接收方能够通过密钥对密文信息进行解密获得明文信息的过程。根据加解密的密钥是否相同,算法可以分为对称加密、非对称加密、对称加密和非
?博客主页:https://xiaoy.blog.csdn.net?本文由呆呆敲代码的小Y原创,首发于CSDN??学习专栏推荐:Unity系统学习专栏?游戏制作专栏推荐:游戏制作?Unity实战100例专栏推荐:Unity实战100例教程?欢迎点赞?收藏⭐留言?如有错误敬请指正!?未来很长,值得我们全力奔赴更美好的生活✨------------------❤️分割线❤️-------------------------
嗨~大家好,这里是可莉!今天给大家带来的是7个C语言的经典基础代码~那一起往下看下去把【程序一】打印100到200之间的素数#includeintmain(){ inti; for(i=100;i 【程序二】输出乘法口诀表#includeintmain(){inti;for(i=1;i 【程序三】判断1000年---2000年之间的闰年#includeintmain(){intyear;for(year=1000;year 【程序四】给定两个整形变量的值,将两个值的内容进行交换。这里提供两种方法来进行交换,第一种为创建临时变量来进行交换,第二种是不创建临时变量而直接进行交换。1.创建临时变量来
在Ruby中,是否有一种简单的方法可以将n维数组中的每个元素乘以一个数字?这样:[1,2,3,4,5].multiplied_by2==[2,4,6,8,10]和[[1,2,3],[1,2,3]].multiplied_by2==[[2,4,6],[2,4,6]]?(很明显,我编写了multiplied_by函数以区别于*,它似乎连接了数组的多个副本,不幸的是这不是我需要的)。谢谢! 最佳答案 它的长格式等价物是:[1,2,3,4,5].collect{|n|n*2}其实并没有那么复杂。你总是可以使你的multiply_by方法:c
我正在使用Ruby解决一些ProjectEuler问题,特别是这里我要讨论的问题25(Fibonacci数列中包含1000位数字的第一项的索引是多少?)。起初,我使用的是Ruby2.2.3,我将问题编码为:number=3a=1b=2whileb.to_s.length但后来我发现2.4.2版本有一个名为digits的方法,这正是我需要的。我转换为代码:whileb.digits.length当我比较这两种方法时,digits慢得多。时间./025/problem025.rb0.13s用户0.02s系统80%cpu0.190总计./025/problem025.rb2.19s用户0.0
我正在构建一个小部件来显示奥运会的奖牌数。我有一个“国家”对象的集合,其中每个对象都有一个“名称”属性,以及奖牌计数的“金”、“银”、“铜”。列表应该排序:1.首先是奖牌总数2.如果奖牌相同,按类型分割(金>银>铜,即2金>1金+1银)3.如果奖牌和类型相同,则按字母顺序子排序我正在用ruby做这件事,但我想语言并不重要。我确实找到了一个解决方案,但如果感觉必须有更优雅的方法来实现它。这是我做的:使用加权奖牌总数创建一个虚拟属性。因此,如果他们有2个金牌和1个银牌,加权总数将为“3.020100”。1金1银1铜为“3.010101”由于我们希望将奖牌数排序为最高的,因此列表按降序排
我想为名字验证编写一个正则表达式。正则表达式应包括所有字母(拉丁/法语/德语字符等)。但是我想从中排除数字并允许-。所以基本上它是\w(减)数(加)-。请帮忙。 最佳答案 ^[\p{L}-]+$\p{L}匹配anykindofletterfromanylanguage. 关于ruby-on-rails-rails中的正则表达式匹配[\w]和"-"但不匹配数字,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.c