zoukankan      html  css  js  c++  java
  • python中数组与多维数组用法介绍

    增加时a.append( 'a ')就可以了。只要按顺序加,就没有问题 。
    使用时,完全可以使用下标:

    代码如下 复制代码
    a[0]
    a[1]

    但出果引用不存在的下标,则会引发异常。这时,你需要先添加元素,再引用就没有问题 了。如果想预先保留空间,可以使用循环来给list,每个元素一个缺省值,再引用就不会有问题 了。
    如:

    代码如下 复制代码
    a=[]
    for i in range(100):
    a.append([])
    for j in range(100):
    a[i].append(0)

    这样就生成了一个100*100缺省值为0的数组。


    #创建一个宽度为3,高度为4的数组
    #[[0,0,0],
    # [0,0,0],
    # [0,0,0],
    # [0,0,0]]
    myList = [[0] * 3] * 4但是当操作myList[0][1] = 1时,发现整个第二列都被赋值,变成

    [[0,1,0],

    [0,1,0],

    [0,1,0],

    [0,1,0]]

    为什么...一时搞不懂,后面翻阅The Python Standard Library 找到答案

    list * n—>n shallow copies of list concatenated, n个list的浅拷贝的连接

    例:

    代码如下 复制代码
    >>> lists = [[]] * 3
    >>> lists
    [[], [], []]
    >>> lists[0].append(3)
    >>> lists
    [[3], [3], [3]][[]]

    是一个含有一个空列表元素的列表,所以[[]]*3表示3个指向这个空列表元素的引用,修改任何

    一个元素都会改变整个列表:

    所以需要用另外一种方式进行创建多维数组,以免浅拷贝:

    代码如下 复制代码
    >>> lists = [[] for i in ra(www.111cn.net)nge(3)]
    >>> lists[0].append(3)
    >>> lists[1].append(5)
    >>> lists[2].append(7)
    >>> lists

    [[3], [5], [7]]之前的二维数组创建方式为:

    myList = [([0] * 3) for i in range(4)]

    比如, 要动态创建一个 二维数组:

    代码如下 复制代码
    int** pTwoDimArr = new int[10][20];
    pTwoDimArr[0][0] = 5;

    这样好像很直观,不过,编译会出错:

    代码如下 复制代码
    cannot convert from 'int (*)[20] ' to 'int ** '


    如果这样:

    代码如下 复制代码
    int pTwoDimArr[10][20];
    pTwoDimArr[0][0] = 5;

    是可以的,但是 这个数组的内存却是在栈上分配的,所以,

    代码如下 复制代码
    void main(){
    int pTwoDimArr[1000][1000];
    }

    编译没问题,运行就会死掉

    作为全局变量是可以的,但最好杜绝吧

    代码如下 复制代码
    int pTwoDimArr[1000][1000];
    void main(){
    }


    这样:

    代码如下 复制代码
    int (*pTwoDimArr)[1000] = new int[1000][1000];
    pTwoDimArr[0][0] = 5;

    动态分配是可以的, 一来记得释放内存,二来维数还是要固定的(第一维可变),是不是有些不爽

    因为 C++ 是“静态”语言, 在编译期要确定好一切,所以在多维数组的定义时除了第一维可变外,其他几维都要固定为常数,因为数组在内存中是线性存储的。
    from:http://www.111cn.net/phper/python/41780.htm

  • 相关阅读:
    Gerrit 系统初探 (已转移到 https://steemit.com/gerrit/@linvictor88/gerrit )
    Iaas概述
    题解西电OJ (Problem 1007 -做一名正气的西电人 )--长整型计算
    题解西电OJ (Problem 1005 -跳舞毯)--动态规划
    题解西电OJ (Problem 1004 -亚特兰提斯)--最小生成树
    题解西电OJ (Problem 1003 -最喜欢的数字)--动态规划
    题解西电OJ (Problem 1008
    题解西电OJ (Problem 1006
    HTML-css selector
    Android--应用开发3(Android layout XML属性)
  • 原文地址:https://www.cnblogs.com/alibai/p/4027324.html
Copyright © 2011-2022 走看看