Python 的深拷贝 和 浅拷贝

今天实现Python的排序问题,比如如下的代码:

    def merge(self, l, r):
        if l == r - 1 or l == r:
            return

        mid = (l + r) // 2
        self.merge(l, mid)
        self.merge(mid, r)

        length = r - l
        left = [i for i in self.data[l:mid]]
        right = [i for i in self.data[mid:r]]

        i = j = 0
        k = l
        while i < len(left) and j < len(right):
            if left[i] < right[j]:
                self.data[k] = left[i]
                i += 1
            else:
                self.data[k] = right[j]
                j += 1
            k += 1
        if i == len(left):
            while k - l < length:
                self.data[k] = right[j]
                k += 1
                j += 1
        else:
            while k - l < length:
                self.data[k] = left[i]
                i += 1
                k += 1

    def MergeSort(self):
        len = self.n
        self.merge(0, len)
        return self.data

以上是正确的写法,但是一开始的写法是直接使用了:

left = self.data[l:mid]
right = self.data[mid+1:r]

这样子实际上leftright 就是一个实际的应用,也就是说修改这个的时候会同时原来的self.data 的数据,为了避免这个问题,我们的拷贝必须使用 一些特殊的技巧:

newList = list(arr[l:r])
newList = [i for i in arr[l:r]]

import copy as cp # emmmm,这个缩写,233333
newList = cp.copy(arr[l:r])

一般不用引入一个包来解决问题,前两个已经很不错了

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值