从入门到自闭之Python集合,深浅拷贝(大坑)
小数据池
- int: -5~256
- str:
- 字母,数字长度任意符合驻留机制
- 字符串进行乘法时总长度不能超过20
- 特殊符号进行乘法时只能乘以0
代码块:
一个py文件,一个函数,一个模块,终端中的每一行都是代码块
- int:-5~无穷大
- str:
- 定义字符串的时候可以是任意的
- 字符串(字母,数字)进行乘法时总长度不得超过20
- 特殊字符(中文,符号)进行乘法时乘以0或者1
- bool:
- True
- False
is是判断两边的内存地址是否相同
==判断两个值是否相等
代码块、小数据池同在的情况下先执行代码块。
驻留机制:节省内存空间,提升效率(减少了开辟空间和销毁空间的耗时)
集合
集合是python中的数据类型之一
定义方式:set
- 集合就是一个没有值的字典
字典的值:唯一,不可变
集合:无序,可变
集合天然去重
# s = {1,23,4,2,1,2,3,1}
print(s)
输出结果:{1, 2, 3, 4, 23}
# 面试题:
lst = [1,223,1,1,2,31,231,22,12,3,14,12,3] print(list(set(lst)))
输出结果:[1, 2, 223, 3, 231, 12, 14, 22, 31]
s = {} #空字典
s = set() #空集合
增:
s = set() s.add("alex") #直接添加, 输出结果为:{'alex'} s.update("wusir") #迭代添加, 输出结果为:{'r', 'i', 'w', 's', 'u'} set("wusir") #迭代添加, 输出结果为:set()
删
s = {100,0.1,0.5,1,2,23,5,4}
s.remove(4) # 通过元素删除
print(s)
s.clear() # 清空
s.pop() # 随机删除 (最小的)
print(s)
改:
- 先删后加
查:
- for 循环
其他操作:
- 差集--“-”
- 交集--“&”
- 并集--“|”-管道符
- 反交集--“^”
- 子集--“>”返回的是一个布尔值
- 父集(超集)--"<"返回的是一个布尔值
- 冻结集合:frozenset()
深浅拷贝
赋值:将多个变量指向一个同一个内存地址就是赋值
浅拷贝:
只拷贝第一层元素的地址,只有修改第一层的时候元数据不受影响
给可变数据类型进行添加的时候源数据会受影响
= 是修改,.append是添加
可变数据类型能够添加和修改,不可变数据类型只能修改
a = [1,2,3,[4,5]]
b = a[:] # 浅拷贝
print(id(a[-1][0]))
print(id(b[-1][0]))
a.append(9)
print(a)
print(b)
a = [1,2,3,[4,5,6,[9,10]],67]
b = a # 赋值
b = a[:]
a[-2].append(10)#[1, 2, 3, [4, 5, 6, [9, 10], 10], 67]
a[-2][-1].append(10)#[1, 2, 3, [4, 5, 6, [9, 10, 10]], 67]
print(b)
深拷贝:不可变数据类型内存地址共用,可变数据类型新开辟一个空间
# import copy # 导入 copy模块
a = [1,2,3,[4,5],6]
b = copy.deepcopy(a)
print(id(a[-2]))#2812949845896
print(id(b[-2]))#2812949847304
print(a)
print(b)
print(a == b) #True
print(id(a),id(b))
print(a is b) #False
可变数据类型:list(列表),dict(字典),set(集合)
不可变数据类型:int(整型),str(字符串),tuple(元祖),bool(布尔值)
从入门到自闭之Python集合,深浅拷贝(大坑)的更多相关文章
- python学习打卡 day07 set集合,深浅拷贝以及部分知识点补充
本节的主要内容: 基础数据类型补充 set集合 深浅拷贝 主要内容: 一.基础数据类型补充 字符串: li = ["李嘉诚", "麻花藤", "⻩海峰 ...
- 6.Python初窥门径(小数据池,集合,深浅拷贝)
Python(小数据池,集合,深浅拷贝) 一.小数据池 什么是小数据池 小数据池就是python中一种提高效率的方式,固定数据类型,使用同一个内存地址 小数据池 is和==的区别 == 判断等号俩边的 ...
- Python基础知识(六)------小数据池,集合,深浅拷贝
Python基础知识(六)------小数据池,集合,深浅拷贝 一丶小数据池 什么是小数据池: 小数据池就是python中一种提高效率的方式,固定数据类型使用同一个内存地址 代码块 : 一个文 ...
- Python原理 -- 深浅拷贝
python原理 -- 深浅拷贝 从数据类型说开去 str, num : 一次性创建, 不能被修改, 修改即是再创建. list,tuple,dict,set : 链表,当前元素记录, 下一个元素的位 ...
- Python的深浅拷贝
Python的深浅拷贝 深浅拷贝 1. 赋值,对于list, set, dict来说, 直接赋值. 其实是把内存地址交给变量并不是复制一份内容 list1 = [']] list2 = list1 p ...
- 从入门到自闭之python初识
Day 01 整型: 对比: 在python 2 版本中有整型,长整型long 在python 3 版本中全部都是整型 用于计算和比较 整型和布尔值的转换 二进制转换成十进制: print (int ...
- day07 python列表 集合 深浅拷贝
day07 python 一.知识点补充 1."".join() s = "".join(('1','2','3','4','5')) #将字符串 ...
- python摸爬滚打之day07----基本数据类型补充, 集合, 深浅拷贝
1.补充 1.1 join()字符串拼接. strs = "阿妹哦你是我的丫个哩个啷" nw_strs = "_".join(strs) print(nw_s ...
- Python学习基础(二)——集合 深浅拷贝 函数
集合 # 集合 ''' 集合是无序不重复的 ''' # 创建列表 l = list((1, 1, 1)) l1 = [1, 1, 1] print(l) print(l1) print("* ...
随机推荐
- Python中的函数递归思想,以及对比迭代和递归解决Fibonacci数列
什么是递归?简单的说就是:函数自身调用自身. “普通程序员用迭代,天才程序员用递归” 虽然递归 在运行时会不断出栈压栈,调用底层的寄存器,造成空间上的占用以及时间上的缓慢, 但在一些算法上面仍然是递归 ...
- AT3576 Popping Balls
AT3576 Popping Balls 好题!一种以前没怎么见过的思路! %%ywy 以什么方式,什么位置统计本质不同的方案,才能不重不漏是处理所有计数问题的主心骨. 本题难以容斥.难以DP. 所以 ...
- 16.合并两个排序的链表 Java
题目描述 输入两个单调递增的链表,输出两个链表合成后的链表,当然我们需要合成后的链表满足单调不减规则. 解题思路 两种解法:递归和非递归 参考代码 /* public class ListNode { ...
- 预处理、const、static与sizeof-#pragma pack的作用
1:有如下代码: #include <iostream.h> #pragma pack(1) struct test{ char c; short s1; short s2; int i; ...
- Leetcode题目96.不同的二叉搜索树(动态规划-中等)
题目描述: 给定一个整数 n,求以 1 ... n 为节点组成的二叉搜索树有多少种? 示例: 输入: 3 输出: 5 解释: 给定 n = 3, 一共有 5 种不同结构的二叉搜索树: 1 3 3 2 ...
- 【log4j】log4j.properties 文件示例
# 下面的文件内容是写程序长期要用的,放在这里留个底#Output information(higher than INFO) to stdout and file.info/debug/error ...
- linux(redhat)安装jdk1.8
第一步:下载Linux环境下的jdk1.8文件 我的Linux是32位的,因此我下载jdk-8u144-linux-i586.tar.gz文件. 下载链接地址:http://www.oracle.co ...
- LC 794. Valid Tic-Tac-Toe State
A Tic-Tac-Toe board is given as a string array board. Return True if and only if it is possible to r ...
- LC 901. Online Stock Span
Write a class StockSpanner which collects daily price quotes for some stock, and returns the span of ...
- js函数节流和防抖的理解与实现
一:函数防抖1.理解:触发高频事件后n秒内函数只会执行一次,如果n秒内高频事件再次被触发,则重新计算时间2.思路:每次触发事件时都取消之前的延时调用方法 3.实现: function debounce ...