为什么这个Python解决方案不是就地解决方案?

2024-04-26 13:48:32 发布

您现在位置:Python中文网/ 问答频道 /正文

我在一次采访中被问到这个问题。我从招聘人员那里得到反馈,说我没有及时解决这个问题。我想知道为什么这个解决方案不到位?我错过了什么?你知道吗

输入是字符列表,如['h'、'o'、'w'、''、'a'、'r'、'e'、''、'y'、'o'、'u'、'?']. 输出应该是字符串,如?你是怎样的。你知道吗

charArr = ['h','o','w',' ','a','r','e',' ','y','o','u','?']
#output = ?you are how
class Solution():
    def reverseStr(self,charArr):
        charArr = ''.join(charArr).split()[::-1]
        for i in range(len(charArr)):
            if not charArr[i][-1].isalnum():
                charArr[i] = charArr[i][-1] + charArr[i][:-1]
        print ' '.join(charArr)
s1 = Solution()
s1.reverseStr(charArr)

Tags: 字符串you列表output人员解决方案字符are
1条回答
网友
1楼 · 发布于 2024-04-26 13:48:32

就地解决方案永远不会为作为参数传递的列表分配新值,因为如果这样做,调用方传递的列表的值在调用后不会更改。你知道吗

您可以看到,在发布代码之后执行print(charArr)时,它只会打印原始列表。你知道吗

可以使用reverse()方法反转列表中的值。语法list[start:end] = ...也可以用来改变列表。你知道吗

以下是正确解决挑战的方法:

def reverseStr(charArr):
    charArr.reverse() # this is in-place
    start = 0
    for end in range(1, len(charArr)+1):
        if end >= len(charArr) or charArr[end].isalnum() != charArr[end-1].isalnum():
            charArr[start:end] = charArr[start:end][::-1] # in-place reversal of word
            start = end

charArr = ['h','o','w',' ','a','r','e',' ','y','o','u','?']
reverseStr(charArr)
print (charArr) # important to test that charArr changed == proof of "in-place"

相关问题 更多 >