题目描述:给定一个数字字符串 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 []