用于检查我们是否可以在 Python 中从片段形成数组的程序
假设我们有一个数组nums,其中所有元素都是唯一的,并且有另一个数组,其中包含不同的较小数组,称为pieces。我们必须检查是否可以通过以任何顺序将数组连接成块来获得主数组nums。但是我们不允许对每个数组pieces[i]中存在的元素重新排序。
因此,如果输入类似于nums=[5,1,12,36,2,47,6]件=[[2,47,6],[12,36],[1],[5]],那么输出将为True,因为我们可以按照[[5],[1],[12,36],[2,47,6]]的顺序连接它们以获得主数组。
示例(Python)
让我们看看以下实现以获得更好的理解-
def solve(nums, pieces):
temp = []
for p in pieces:
if p[0] not in nums:
return False
l = len(p)
indx = nums.index(p[0])
if nums[indx:indx+l] != p:
return False
else:
temp.extend(p)
if len(nums) == len(temp):
return True
else:
return False
nums = [5,1,12,36,2,47,6]
pieces = [[2,47,6],[12,36],[1],[5]]
print(solve(nums, pieces))输入
[5,1,12,36,2,47,6], [[2,47,6],[12,36],[1],[5]]输出结果
True
热门推荐
10 对患者生日祝福语简短
11 结婚祝福语简短装备
12 周岁祝福语学生文案简短
13 订婚领证祝福语简短精辟
14 导师获奖祝福语大全简短
15 新婚购房祝福语简短精辟
16 牛年祝福语简短的爱人
17 送芒果的祝福语简短
18 送给学长毕业祝福语简短