zoukankan      html  css  js  c++  java
  • 05 数组与链表算法

    1. 静态数据结构( static data structure )
      数组:使用连续分配的内存空间( contiguous allocation )来存储有序表中的数据。读取修改任一元素的时间都是固定的,删除加入数据时需要移动大量的数据。
      在建立静态数据结构的初期就必须声明最大可能要占用的固定内存空间,因此容易造成内存的浪费。
    2. 动态数据结构( dynamic data structure )
      链表( linked list ):使用不连续的内存空间存储具有线性表特性的数据。数据的插入删除方便,不需要移动大量数据,查找时必须按顺序找到该数据,设计麻烦。
      内存分配是在程序执行时才进行的,不需要事先声明,充分节省内存。
    • 矩阵相乘
      矩阵 A(M, N) , 矩阵 B(N, P) -> 矩阵 C(M, P)
      展开成一维数组进行操作
      赋值:

        for i in range(M):
            for j in range(N):
                A[ i * N + j ] = num
      

      相乘:

        for i in range(M):
            for j in range(P):
                temp = 0
                for k in range(N):
                    temp = temp + int( A[ i * N + k ] ) * int( B[ k * P + j ] )
                C[ i * P + j ] = temp
      
    • 转置矩阵
      矩阵 A(M, M)

        for i in range(M):
            for j in range(i):
                if i != j:
                    A[i][j], A[j][i] = A[j][i], A[i][j]
      
    • 建立单向链表

      • 动态分配产生链表节点 —— 定义一个类
        定义一个指针字段:指向下一个节点
        定义至少一个数据字段

          class student:
              def __init__(self):
                  self.name = ""
                  self.score = 0
                  self.next = None
        

        建立学生节点的单向链表:

          class Student:
              def __init__(self):
                  self.name = ""
                  self.score = 0
                  self.next = None
        
          head = Student()
          ptr = head  # 存取指针的位置
          for i in range(5):
              new_data = Student()
              new_data.name = "张三"
              new_data.score = 90
              # ptr :指针,不破坏 head
              ptr.next = new_data
              ptr = ptr.next
          
          print('-->', ptr)
          print(head)
          for i in range(6):
              print('==>', head.next)
              head = head.next
        
      • 单向链表的连接功能
        级联 (concatenation)

          def concatlist(ptr1, ptr2):
              ptr = ptr1
              while ptr.next != None:
                  ptr = ptr.next
              ptr.next = ptr2
              return ptr1
        
      • 单向链表的节点删除

        1. 删除第一个节点
             top = head
             head = head.next
          
        2. 删除最后一个节点
             ptr.next = tail
             ptr.next = None
          
        3. 删除中间节点 Y
             Y = ptr.next
             ptr.next = Y.next
          
          def del_ptr(head, ptr):
              top = head
              if ptr.num == top.num:  # [ 1 ] 删除第一个节点
                  head = head.next
              else:
                  while top.next != ptr:  # 找到删除节点的前一个位置
                      top = top.next
                  if ptr.next == None:  # [ 2 ] 删除最后一个节点
                      top.next = None
                  else:
                      top.next = ptr.next  # [ 3 ] 删除中间节点 Y
              return head
        
          ptr = head
          find = 0  # 未找到标记
          while ptr != None:
              if ptr.num == findword:  # findword 要查找的 num
                  ptr = del_ptr(head, ptr)
                  head = ptr
                  find += 1
              ptr = ptr.next
          if find == 0:
              print("没找到。")
        
      • 单向链表的反转
        无从知道上一个节点的位置,需要 3 个指针变量。

          def invert(head):  # head 是链表的头指针
              ptr = head
              before = None
              while ptr is not None:
                  last = before
                  before = ptr
                  ptr = ptr.next
                  before.next = last  # 指向前一个
              return before
        

    数组结构类型通常包含哪几个属性:起始地址、维数、索引上下限、元素个数、数组类型。

    在链表 T 的节点 X 之后添加节点 I:

      class Node:
          def __init__(self):
              self.data = 0
              self.next = None
      
      def insert(T, X, val):
          I = Node()
          I.data = val
          if T is None:
              T = I
              I.next = None
          else:
              I.next = X.next
              X.next = I
          return T
    
  • 相关阅读:
    用textfield制作richTextEdit
    鼠标手势替换闪烁不停地问题
    怎样在FlexBuilder中使用FlashCS中的组件[翻译]
    一个可以减少代码输入量的用法
    使用Flex library project
    初级程序员进步的几个标志
    给flashBuilder整几个快捷键
    在纯AS工程中嵌入个别字体方法
    软件设计中应重视的非技术因素
    ASP.NET MVC 2.0 Html.RenderPartial & Html.RenderAction
  • 原文地址:https://www.cnblogs.com/catyuang/p/11760485.html
Copyright © 2011-2022 走看看