【问题标题】:Why does my code fail on this SIMPLE exercise?为什么我的代码在这个简单的练习中失败了?
【发布时间】:2017-06-06 19:29:42
【问题描述】:

我正在做一个编码练习:

给定一个整数序列作为一个数组,判断是否有可能通过从数组中删除不超过一个元素来获得一个严格递增的序列。

示例

  • 对于序列 = [1, 3, 2, 1],输出应该是 假的;

    这个数组中没有一个元素可以被移除以获得严格递增的序列。

  • 对于序列 = [1, 3, 2],输出应该是 是的;

    您可以从数组中删除 3 以获得严格递增的序列 [1, 2]。或者,您可以删除 2 以获得严格递增的序列 [1, 3]。

.

所以我写了这段代码:

def almostIncreasingSequence(sequence):
    first_list, second_list = [x for x in sequence], [x for x in sequence]
    for i in range(len(sequence)-1):
        if sequence[i] >= sequence[i+1]:
            first_list.remove(sequence[i])
            second_list.remove(sequence[i+1])
            break

    if first_list == sorted(set(first_list)) or second_list == sorted(set(second_list)):
        return True
    else:
        return False

代码通过了 13/15 次测试。

以下是我的代码失败的 2 个输入:

[1, 2, 3, 4, 3, 6]

[3, 5, 67, 98, 3]

两个输入都应返回 True,但我的代码返回 False。有什么想法吗?

【问题讨论】:

  • sequence的类型是什么?是列表吗?
  • 是的,它是一个列表。
  • 那么:first_list, second_list = [x for x in sequence], [x for x in sequence] 有什么意义?
  • 复制列表的pythonic方法是first_list = sequence[:]
  • @cezar 制作两个列表副本的目的是为了以后能够比较它们。

标签: python arrays


【解决方案1】:

阅读list.remove

从列表中删除第一个值为 x 的项目。如果没有这样的项目是错误的。

>>> l = [1, 2, 3, 4, 3, 6]
>>> l.remove(3)
>>> print(l)
[1, 2, 4, 3, 6]

pop(index)代替remove(value)

first_list.pop(i)
second_list.pop(i+1)

【讨论】:

  • 非常感谢,在这个练习上坚持了至少几个小时,你的解释绝对完美。
【解决方案2】:

获取您的第一个列表,[1, 2, 3, 4, 3, 6]。在 first_listsecond_list 上运行 for 循环后,这些变量的值是:

In [9]: first_list
Out[9]: [1, 2, 3, 3, 6]

In [10]: second_list
Out[10]: [1, 2, 4, 3, 6]

if 的第一部分是False,因为:

In [12]: sorted(set(first_list))
Out[12]: [1, 2, 3, 6]

通过将列表放入一组中,您已经失去了一个 3。

if 的第二部分是False,因为second_list 没有排序。

所以,if 语句的两个部分都是 False,而您的函数返回 False

【讨论】:

  • 嗯,在 for 循环之后,第一个列表变成了,就像你说的,[1,2,3,3,6]。但是,第二个列表应该变成: [1, 2, 3, 4, 6] 对吧?因为我们要删除索引 4 (i+1) 处的元素。在这种情况下,它等于 sorted(set([1, 2, 3, 4, 6)) 并且函数应该返回 True。还是我在这里遗漏了什么?
  • 哦,没关系,Tomasz 的回答解释了为什么我错而你是对的。
  • 完整答案是这个答案和@Tomasz 的组合。
猜你喜欢
  • 1970-01-01
  • 1970-01-01
  • 2016-09-23
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2022-12-04
相关资源
最近更新 更多