加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

Swift 最大子数组

发布时间:2020-12-14 06:35:45 所属栏目:百科 来源:网络整理
导读:用递归吧,分治策略,求最大子数组 //: Playground - noun: a place where people can playimport UIKitvar str = "Hello,playground"var A = [13,-3,-25,20,-16,-23,18,-7,12,-5,-22,15,-4,7]for i in 0..A.count { print(A[i]) }func FINDMAXCROSSINGSUBAR

用递归吧,分治策略,求最大子数组

//: Playground - noun: a place where people can play

import UIKit

var str = "Hello,playground"
var A = [13,-3,-25,20,-16,-23,18,-7,12,-5,-22,15,-4,7]
for i in 0..<A.count {
    print(A[i])
    
}

func FINDMAXCROSSINGSUBARRAY(A:[Int],low:Int,mid:Int,high:Int)->(maxleft:Int,maxright:Int,lr:Int){
    var sum = 0
    var maxleft = 0
    var maxright = 0
    var left_sum = -1000;
    for i in stride(from: mid,through: low,by: -1)  {
        sum = A[i] + sum
        if(sum > left_sum)
        {
            left_sum = sum
            maxleft = i
        }
        
    }
    var right_sum = -1000
    sum = 0
    for j in mid+1...high
    {
        sum += A[j]
        if(sum > right_sum)
        {
            right_sum = sum
            maxright = j
        }
    }
    
    return(maxleft,maxright,left_sum+right_sum)
    
}

func FINDMAXIMUMSUBARRAY(A:[Int],high:Int) ->(l:Int,h:Int,zhi:Int)
{
    if (high == low) {
        return (low,high,A[low])
    }
    else {
        let mid = (low+high)/2
        let a = FINDMAXIMUMSUBARRAY(A: A,low: low,high: mid)    
        let b = FINDMAXIMUMSUBARRAY(A: A,low: mid+1,high: high)
        let c = FINDMAXCROSSINGSUBARRAY(A: A,mid: mid,high: high)
        if(a.zhi >= b.zhi && a.zhi >= c.lr)
        {return (a.l,a.h,a.zhi)}
        else if (b.zhi >= a.zhi && b.zhi >= c.lr)
        { return (a.l,b.h,b.zhi)}
        else {return (c.maxleft,c.maxright,c.lr)}
    }
}

FINDMAXIMUMSUBARRAY(A: A,low: 0,high: A.count-1)

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读