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

连续子链表最大和

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

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

全部评论

相关推荐

有工作后先养猫:太好了,是超时空战警,我们有救了😋
点赞 评论 收藏
分享
点赞 收藏 评论
分享
牛客网
牛客企业服务