• 博客园logo
  • 会员
  • 周边
  • 新闻
  • 博问
  • 闪存
  • 众包
  • 赞助商
  • Chat2DB
    • 搜索
      所有博客
    • 搜索
      当前博客
  • 写随笔 我的博客 短消息 简洁模式
    用户头像
    我的博客 我的园子 账号设置 会员中心 简洁模式 ... 退出登录
    注册 登录
武纪亨
博客园    首页    新随笔    联系   管理    订阅  订阅
数据类型之内置方法

内容概要

  • 队列与堆栈练习题

  • 列表内置方法(补充)

  • 字典内置方法

  • 元组内置方法

  • 元组相关练习题

  • 集合内置方法

一、队列与堆栈练习题

  队列FIFO:先进先出

  堆栈FILO:先进后出

  # 用列表及内置方法模拟出上述两个数据结构的特性

  # 1.先定义一个空列表
  l1 = []
  # 2.先进
  l1.append(123)
  l1.append(456)
  l1.append(789)
  print(l1)
  # 3.先出
  l1.pop(0)
  l1.pop(0)
  l1.pop(0)
  print(l1)

  # 1.定义一个空列表
  l2 = []
  # 2.先进
  l2.append(111)
  l2.append(222)
  l2.append(333)
  print(l2)
  # 3.后出
  l2.pop()
  l2.pop()
  l2.pop()
  print(l2)

二、列表其他方法列表

  # l1 = [44, 88, 77, 99, 11, 33, 22, 66]
  # l1.sort()  # 默认是升序

  # l1 = [44, 88, 77, 99, 11, 33, 22, 66]
  # l1.sort(reverse=True) # 参数制定 降序

  # l1 = [44, 88, 77, 99, 11, 33, 22, 66]
  # l1.reverse()  # 顺序颠倒

  # l1 = [44, 88, 77, 99, 11, 33, 22, 66]

  # print(l1[1:5])  # [88, 77, 99, 11]

  # print(l1[:4])  # [44, 88, 77, 99]

  # print(l1[:])  # [44, 88, 77, 99, 11, 33, 22, 66]

  # print(l1[2:-1])  # [77, 99, 11, 33, 22]

  # print(l1[1:])  # [88, 77, 99, 11, 33, 22, 66]

  # 冒号左右两边不写数字默认全部都要

  # 冒号左边不写默认从头开始

  # 冒号右边不写默认到尾部

  # ll1 = [999, 111]
  # ll2 = [555, 444, 333, 222]
  # print(ll1 > ll2)  # True

  """列表比较运算采用相同索引元素比较 只要有一个比出了结果就直接得出结论"""

  # i1 = 'abc'
  # i2 = 'efd'
  # print(i1 > i2)  # False

  """字符串比较大小也是按照索引位置内部转成ASCII对应的数字比较"""

三、字典内置方法

  # dic = {'name': 'jason', 'age': 18, 'bobbies': ['read', 'sellp']}

  #1.按K取值 K不存在会直接报错
  # print(dic['name'])  # jason
  # print(dic['pwd'])  # 报错

  # 2.按K修改值 新增键值对(使用频率最高) 

  # dic = {'name': 'jason', 'age': 18, 'hobbies': ['read', 'sellp']}

  # dic['name'] = 'jasonNB'

  # dic['hobbies'].append('play game')
  # print(dic)  # {'name': 'jason', 'age': 18, 'hobbies': ['read', 'sellp', 'play game']}

  # dic['pwd'] = 123  # 键不存在为新增键值对

  # print(dic)  # {'name': 'jason', 'age': 18, 'hobbies': ['read', 'sellp'], 'pwd': 123}

  # 3.统计字典内部键值对的个数

  # print(len(dic))  # 3

  # 4.成员运算 默认值暴露K

  # print('name' in dic)  # True

  # print('jason' in dic)  # False

   # 5.删除元素

  # 方式1

  # del  

  # del dic['name']

  # print(dic)  # {'age': 18, 'hobbies': ['read', 'sellp']}

                

   # 方式2  指定K弹出键值对 给出V

  # dic.pop(('age'))

  # print(dic)  # {'name': 'jason', 'hobbies': ['read', 'sellp']}

                

  # 方式3  弹出键值对 组织成元组的形式 第一元素是K 第二个元素是V(了解即可)

  # dic.popitem()

  # print(dic)  # {'name': 'jason', 'age': 18}

   # 6.获取V值

  # print(dic['name'])  # jason

  # print(dic['xxx'])  # 键不存在 直接报错 按K取值不太推荐该方法

  # print(dic.get('name'))  # jason

  # print(dic.get('weight'))  # None 键不存在 不会报错 返回None

  # print(dic.get('name', 'hahaha'))  # jason

  # print(dic.get('weiguht', '哈哈哈'))  # 哈哈哈  第二个参数可以在K不存在的时候自定义返回信息

                

  # 7. keys()  values() items() 在python2中是列表 在python3中是迭代器(老母猪)

  # print(dic.keys())  # dict_keys(['name', 'age', 'hobbies'])  获取字典所有的键 看成列表即可

  # print(dic.values())  # dict_values(['jason', 18, ['read', 'sellp']])  获取字典所有的之 看成列表即可

  # print(dic.items())  # dict_items([('name', 'jason'), ('age', 18), ('hobbies', ['read', 'sellp'])])  获取字典里所有的键值对 组成列表套元组的形式 元组内有两个元素 第一个为K第二个为V

                

四、字典需要了解的方法

  # 1.更新字典 键存在则修改 不存在则创建

  # dic = {'name': 'jason', 'age': 18, 'hobbies': ['read', 'sellp']}

  # dic.update({'name': 'jasonNB', 'pwd' : 123})

  # print(dic)  # {'name': 'jasonNB', 'age': 18, 'hobbies': ['read', 'sellp'], 'pwd': 123}

  # 2.初始化字典

  """笔试题"""

  # res = dict.fromkeys(['k1', 'k2', 'k3'], []) 

  # res['k1'].append(111)  # {'k1': [111], 'k2': [111], 'k3': [111]}
  # res['k2'].append(222)  # {'k1': [111, 222], 'k2': [111, 222], 'k3': [111, 222]}
  # res['k3'].append(333)  # {'k1': [111, 222, 333], 'k2': [111, 222, 333], 'k3': [111, 222, 333]}

  # res['k1'] = [111, 222, 333]

  # res['k1'].append(444)

  # print(res)  # {'k1': [111, 222, 333, 444], 'k2': [111, 222, 333], 'k3': [111, 222, 333]}

                

  # 3.当键存在的情况下 不修改而是获取该键相对应的值

  # print(dic.setdefault('name', ('jasonNB')))  # jason

  # 当键不存在的情况下 新增一组键值对 并且该方法的结果是新增的值

  # print(dic.setdefault('pwd', '123'))
  # print(dic)   # {'name': 'jason', 'age': 18, 'hobbies': ['read', 'sellp'], 'pwd': '123'}

 五、元组内置方法

  """

  小括号括起来 内部存放多个元素 元素与元素逗号隔开 元素可以是任意数据 但是元组内元素不支持‘修改’(索引指向的元素的内存地址不能改变)  也可以简单的认为他是一个不可变的列表

  """

  # 类型转换 能够支持for循环的数据都可以转换成元组

  # print(tuple(111))  # 报错

  # print(tuple(11.11))  # 报错

  # print(tuple('hello'))  # ('h', 'e', 'l', 'l', 'o')

  # print(tuple([11, 22, 33]))  # (11, 22, 33)

  # print(tuple({'name' : 'jason', 'age' : 18}))  # ('name', 'age')

  # 元组一道练习题

  # t1 = (111)  # 整型

  # t2 = (11.11)  # 浮点型

  # t3 = ('hello')  # 字符串

  """元组内哪怕只有一个元素 也需要加上逗号"""

  # print(type((111,)))  # <class 'tuple'>

  '''

  容器类型:内部可以存放多个值得数据类型都可以称之为容器类型

    建议:所有的容器类型在储存数据的时候 如果内部只有一个元素 那么也应加上逗号

  '''

  # t = (111, 222, 333, 444, 555)

  # 1.索引取值
  # print(t[1])  # 222
  # print(t[-1])  # 555

  # 2.切片操作

  # print(t[1:4])  # (222, 333, 444)

  # print(t[1:])  # (222, 333, 444, 555)

  # print(t[:])  # (111, 222, 333, 444, 555)

  # 3.步长

  # print(t[1:5:2])  # (222, 444)

  # 4.统计元组内元素的个数

  # print(len(t))  # 5

  # 5.for循环

  # for i in t:

  #   print(t)  

  # 6.count计数

  # print(t.count(111))  # 1

  '''练习题'''

  # t1 = (111, 222, [11, 22, 33])
  # t1[2].append(44)
  # print(t1)  # (11, 22, [111, 222, 333, 44])

          

六、集合去重操作

  # 1.定义空集合需要使用关键字set

  # s1 = set()

  # 2.类型转换 能够支持for循环的数据类型都可以转成集合(元素是不可变类型)

  """集合内元素是无序的"""

  # 去重

  # s1 = {1, 2, 2, 2, 3, 4, 3, 4, 3, 1, 2, 3, 2, 1, 2, 3, 2, 1, 2, 3}
  # print(s1)  # {1, 2, 3, 4}

  # name_list = ['kevin', 'jason', 'jason', 'jason', 'kevin', 'kevin']

  # s1 = set(name_list)
  # print(list(s1))  # ['kevin', 'jason']

  # 1.先将列表转换成集合

  # 2.再将去重之后的集合转换成列表

  """练习题"""

  # ll = [33, 22, 11, 22, 11, 44, 33, 22, 55, 66, 77, 77, 66, 55, 44]
  # 基本要求:去重即可
  # l1 = set(ll)
  # print(l1)
  # l2 = list(l1)
  # print(l2)
  # 拔高要求:去重并保留原来的顺序
  # l3 = []
  # for i in ll:
  #   if i not in l3:
  #  l3.append(i)
  # print(l3)

                 

七、集合关系运算

  # 关系运算

  """两个群里之间做差异比较     共同好友 共同关注..."""

  # friends1 = {"zero", "kevin", "jason", "eg"} # 用户1的好友们
  # friends2 = {"Jy", "ricky", "jason", "eg"} # 用户2的好友们

  1.求两个用户的共同好友

  # print(friends2 & friends1)  # {'eg', 'jason'}

  2.求两个用户所有的好友

  # print(friends2 | friends1)  # {'ricky', 'eg', 'zero', 'Jy', 'kevin', 'jason'}

  3.求用户1独有的好友

  # print(friends1 - friends2)  # {'zero', 'kevin'}

  4.求用户1和用户2独有的好友  

  # print(friends1 ^ friends2)  # {'zero', 'ricky', 'kevin', 'Jy'}

  5.父集与子集

  # s1 = {11, 22 ,33, 44}

  # s2 = {11, 44}

  # print(s1 > s2)  # 判断s1是否是s2的父集  # True

  # print(s2 < s1)  # 判断s2是否是s1的子集  # True

                 

posted on 2021-11-09 22:26  Henrywuovo  阅读(93)  评论(0)    收藏  举报
刷新页面返回顶部
博客园  ©  2004-2026
浙公网安备 33010602011771号 浙ICP备2021040463号-3