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])

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

深拷贝(deep copy)和浅拷贝(shallow copy)是Python中关于对象复制的两个概念。 浅拷贝是指创建一个新的对象,其内容是原始对象的引用。也就是说,新对象与原始对象共享内存地址,对其中一个对象的修改会影响到另一个对象。在Python中,可以使用`copy`模块的`copy()`函数或者对象的`copy()`方法进行浅拷贝深拷贝则是创建一个新的对象,完全复制原始对象及其所有嵌套对象的内容。也就是说,新对象与原始对象完全独立,互不影响。在Python中,可以使用`copy`模块的`deepcopy()`函数或者对象的`deepcopy()`方法进行深拷贝。 下面是一个简单的示例代码来说明深拷贝浅拷贝的区别: ```python import copy # 原始对象 original_list = [1, 2, [3, 4]] print("原始对象:", original_list) # 浅拷贝 shallow_copy_list = copy.copy(original_list) print("浅拷贝对象:", shallow_copy_list) # 修改浅拷贝对象 shallow_copy_list[2][0] = 5 print("修改浅拷贝对象后,原始对象:", original_list) print("修改浅拷贝对象后,浅拷贝对象:", shallow_copy_list) # 深拷贝 deep_copy_list = copy.deepcopy(original_list) print("深拷贝对象:", deep_copy_list) # 修改深拷贝对象 deep_copy_list[2][1] = 6 print("修改深拷贝对象后,原始对象:", original_list) print("修改深拷贝对象后,深拷贝对象:", deep_copy_list) ``` 输出结果为: ``` 原始对象: [1, 2, [3, 4]] 浅拷贝对象: [1, 2, [3, 4]] 修改浅拷贝对象后,原始对象: [1, 2, [5, 4]] 修改浅拷贝对象后,浅拷贝对象: [1, 2, [5, 4]] 深拷贝对象: [1, 2, [3, 4]] 修改深拷贝对象后,原始对象: [1, 2, [5, 4]] 修改深拷贝对象后,深拷贝对象: [1, 2, [3, 6]] ``` 可以看到,对浅拷贝对象的修改会影响到原始对象,而对深拷贝对象的修改不会影响原始对象。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值