842. 将数组拆分成斐波那契序列

题目描述:给定一个数字字符串 S,比如 S = “123456579”,我们可以将它分成斐波那契式的序列 [123, 456, 579]。形式上,斐波那契式序列是一个非负整数列表 F,且满足:0 <= F[i] <= 2^31 - 1,(也就是说,每个整数都符合 32 位有符号整数类型);F.length >= 3;对于所有的0 <= i < F.length - 2,都有 F[i] + F[i+1] = F[i+2] 成立。另外,请注意,将字符串拆分成小块时,每个块的数字一定不要以零开头,除非这个块是数字 0 本身。返回从 S 拆分出来的任意一组斐波那契式的序列块,如果不能拆分则返回 []。
解题思路:首先确定第一个数和第二数,因为可选的数的长度是任意的,因此一次遍历可以选择的长度范围内的第一个数和第二个数,需要注意的就是如果长度大于1,第一个数字不能为0,然后通过斐波拉切数列求和,一次求出后面的数值,然后和对应位置的字符串进行比较,看是否相等,如果不相等那之前跳过当前循环寻找下一个可以构成数列的第一个数和第二个数,相等的话则继续循环知道最后看是否字符串所有数字都进行匹配以及数列长度是否大于2,最后需要注意的就是数列的值不能超过要求的最大值,代码如下:

class Solution:
    def splitIntoFibonacci(self, S: str) -> List[int]:
        size = len(S)
        res = []
        max_num = 2 ** 31 - 1
        for i in range(1, size // 2 + 1):
            res = []
            if i != 1 and S[0] == '0':
                continue
            first = int(S[:i])
            res.append(first)
            for j in range(1, min(size - 2 * i, (size - i) // 2) + 1):
                if j != 1 and S[i] == '0':
                    continue
                second = int(S[i:i+j])
                res.append(second)
                k = i+j
                num1, num2 = first, second
                while(k < size):
                    tmp = str(num1+num2)
                    last = len(tmp) + k
                    if last <= size and S[k:last] == tmp and int(tmp) <= max_num:
                        num1 = num2
                        num2 = int(tmp)
                        k += len(tmp)
                        res.append(num2)
                    else:
                        res = [res[0]]
                        break
                if len(res) >= 3 and k == size:
                    return res
        return []
                
                        
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值