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

连续子链表最大和

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;
    }
};

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

全部评论

相关推荐

爱看电影的杨桃allin春招:我感觉你在炫耀
点赞 评论 收藏
分享
拒绝无效加班的小师弟很中意你:求职意向没有,年龄、课程冗余信息可以删掉,需要提升项目经历。排版需要修改。
点赞 评论 收藏
分享
评论
点赞
收藏
分享
牛客网
牛客企业服务