题解 | #跳台阶扩展问题#

连续子链表最大和

http://www.nowcoder.com/practice/650b68dfa69d492d92645aecd7da9b21

解法一,动态规划解决

/**
 * struct ListNode {
 *	int val;
 *	struct ListNode *next;
 *	ListNode(int x) : val(x), next(nullptr) {}
 * };
 */
int num[100000] = {0};
class Solution {
public:
    int FindGreatestSumOfSubArray(ListNode* head) {
        int n,i = 0;
        while(head != NULL){
            num[i++] = head->val;
            head = head->next;
        }
        n = i;
        long int MAX = num[0],sum = num[0];
        for (int i = 1; i < n; ++i) {
            if (sum < 0 && sum < num[i])
                sum = num[i];
            else
                sum += num[i];
            MAX = max(MAX, sum);
        }
        return MAX;
    }
};

解法二,递归解决,后面补充

全部评论

相关推荐

03-02 08:18
集美大学 Java
钱嘛数字而已:没有赛事奖项么?另外,项目经历字有点多哈,建议突出一下重点:用的什么技术,解决什么问题,达到什么效果。
大家都开始春招面试了吗
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务