python学习笔记(7)容器以及容器的访问使用

一、容器

   1.list列表

     序列是python中最基本的数据结构,序列中的每个元素都分配一个数字,它的位置或索引,第一个索引是0,第二个索引是1,以此类推

    

Built-in mutable sequence.    #以一种可变的序列进行创建

If no argument is given, the constructor creates a new empty list.  
  #如果没有参数来提供,构造器会创建一个新的空的列表
The argument must be an iterable if specified.
  #如果指定参数,那么这个参数必须是可以迭代的量

     类表的数据项不需要具有相同的数据类型

       list创建

       添加元素(list only):append,extends

      删除元素(list only) :del,drop

     根据索引读写(tuple读写)

    判断容器是否为空

    字符串转换

    容器元素数量

    遍历

数组的遍历

#有一个数组,然后再任意给定一个值,找到数组中的两个数,使得他们的和等于给定的数
#如果找得到的话,就返回数组数组中这两个数的索引值,如果找不到的话,就返回-1,-1
def two_sum(numbers,target):
    for i in range(len(numbers)):
        for j in range(i+1,len(numbers)):
            if (numbers[i]+numbers[j]==target):
                return i,j
    return -1,-1

print(two_sum([1,5,3,9,1,0,3,4,6],10))

  2.元组(只读列表)

#元组
t=(1,2,3,'456')
print(type(t))
t[0]='a'
元组不支持赋值操作,也没有append()方法

   

Built-in immutable sequence.      #不可变的序列
    
    If no argument is given, the constructor returns an empty tuple.
    #如果没有参数提供,构造器会返回一个新的空元祖 If iterable is specified the tuple is initialized from iterable's items.   #如果被指定为可以迭代的额,那么这个元组将会从可迭代的元素项进行初始化 If the argument is a tuple, the return value is the same object.
    #如果参数是一个tuple,那么返回的值就是同一个对象

 

  3.dict字典:字典中的每个键值(key=>value)对使用冒号(:)进行分割,每个键值对之间用逗号,进行分割,整个字典都包括在花括号({})中

#dict字典,key-value的结构,key和value可以是任意的值
d={'a':1,'b':2,1:'one',2:'two'}
print(type(dict))#<class 'type'>
print(type(d))#<class 'dict'>
print(d)#{'a': 1, 'b': 2, 1: 'one', 2: 'two'}


#访问元素
print(d['a'])#访问对应的value值
print(d[1])#访问对应的value值

#判断元素是否存在,就是判断key是否存在,一个key对应一个value,如果要一个key对应多个值,key值就用数组
print('a' in d)#判断'a'是不是在key中的
print(3 in d )

#删除元素
del(d[2])
print(d)

#查看字典的长度
print(len(d))

#遍历字典的key
for key in d:
    print(d[key])
print('.........')
#遍历字典中的key,value
for key,value in d.items():
    print(str(key)+':'+str(value)

  4.set集合:是一个无序不重复的元素集合,基本功能包括关系测试和消除重复元素,集合对象还支持union(联合)操作,difference(差)和sysmmetric(对称差集)等数学运算

  

 """
        set() -> new empty set object   #set()表示一个一个新的空的set(对象)
        set(iterable) -> new set object  #set(iterable)表示一个新的set对象
        
        Build an unordered collection of unique elements.    #创建的是一个无序的无重复元素的集合
        # (copied from class doc)
        """

 

  5.python数据类型:empty和None之间的区别 

#向容器中添加元素,空和None是不是一回事
l_a=[]  #l_a是一个空的列表
if not l_a:#如果l_a是空
    print('Empty')#not xx和is None不是一回事
if l_a is None:#如果不是空
    print('None')
最后结果:Empty
注意Empty和None不是一回事,即使是empty元素,但是在内存中还要有一些信息来进行相关的描述,至少分配一个类和内存空间来进行相关的计算,而None是都没有的

  6.切片

    (1)存取序列(列表,元组,字符串)的任意一部分

    (2)格式:seq[开始索引:结束索引:步长]

        默认值

        负数索引

        负数步长

#生成10个元素的数组的方法一
li=list(range(10))
print(li)
#方法二
li=[]
for i in range(10):
    li.append(i)
print(li)

#生成有10个0的数组
li=[0]*10
print(li)
#生成有10个1的数组
li=[1]*10
print(li )

#2维数组
li_2d=[[0]*3]*3
print(li_2d)
#修改元素,修改每行的第一个元素
li_2d[0][0]=100
print(li_2d)

#深拷贝,修改元素只修改第一个元素
li_2d=[[0]*3 for i in range(3)]
li_2d[0][0]=100
print(li_2d)


s={x for x in range(10) if x%2==0}
print(s)

    7.生成器

      (1)创建一个巨大的列表,但是只需要访问其中的少量的几个元素

      (2)...

      (3)..

      (4)生成生成器:列表推倒时用()替换[]

      (5)遍历:next或者for循环

  8.函数对象:   

    def func(a,b,c):  #返回的是一个函数对象
     print(a,b,c)
    print(type(func))  #返回的是 <class 'function'>
  9.模块
    在python中,模块也有类型
     import string
                
      print(type(string)) #<class 'module'>
  10.类
class MyClass(object):
    pass
print(type(MyClass))   #自己定义类的类型是type类

my_class=MyClass()
print(type(my_class))   #对于自己实例化的一个类,这个类的类型是就是实例化类的类型   

  11.作业:反转单向链表

posted @ 2018-10-16 19:24  stone1234567890  阅读(735)  评论(0编辑  收藏  举报