LeetCode-494-Target Sum

这个题也是一道动态规划题目。题意是:给出一系列数和一个目标数,使用+-来使这些数字的和等于给定的目标数,求总共可行的方法数。

例子:输入[1, 1, 1, 1, 1]target = 3,那么:

所以最后的输出结果是:5 继续阅读“LeetCode-494-Target Sum”

LeetCode-120-Triangle

这道题的题意是:给定一个数组形成的三角形,在从三角形的顶部出发的路径中,求节点数值相加结果为最小的和。

例子:输入

那么从顶部到底部最小的一条路径和为:2+3+5+1=11

思路:这是一道逆序的二维动态规划题,和之前看过的一道题–《龙与地下城》非常相似,都是逆序地从下往上求 DP数组。代码很简单,就不多做分析了,相信大家一看就能看懂。

代码如下:

LeetCode-7-Reverse Integer

这道题仍然属于一道简单题。题目描述是这样的:给定一个32位signed int类型的整数,将它进行反转,如输入123返回321,输入-123返回-321。另外,题目下的提示中也说明了一些特殊情况,一种是输入10、100这样末尾是0的数字时应该返回什么,另外一种是反转1000000003 时,结果有可能溢出。

首先我们先来思考一下为什么上面的结果会溢出。输入整数的类型为signed int,因此用二进制形式表示时,第一位是一个符号位,剩下的31位用来表示数字。231 = 2147483648,所以输入数字的范围是-2147483648 ~ 2147483647。而1000000003反转的结果是3000000001,超出了上述范围,因此发生了溢出,此时直接返回0即可。代码如下: