解析C++的线性表链式存储设计与相关的API实现

2020-01-06 14:56:33王旭


main.cpp  
  


#include <iostream> 
#include <cstdio> 
#include "linklist.h" 
 
using namespace std; 
 
typedef struct _Student 
{ 
 LinkListNode node; 
 char name[32]; 
 int age; 
}Student; 
 
int main() 
{ 
 Student s1, s2, s3, s4, s5, s6; 
 s1.age = 21; 
 s2.age = 22; 
 s3.age = 23; 
 s4.age = 24; 
 s5.age = 25; 
 s6.age = 26; 
 
 // 创建链表 
 Student *list = (Student *)LinkList_Create(); 
 
 // 插入结点 
 LinkList_Insert(list, (LinkListNode *)&s1, 0); 
 LinkList_Insert(list, (LinkListNode *)&s2, 0); 
 LinkList_Insert(list, (LinkListNode *)&s3, 0); 
 LinkList_Insert(list, (LinkListNode *)&s4, 0); 
 LinkList_Insert(list, (LinkListNode *)&s5, 0); 
 LinkList_Insert(list, (LinkListNode *)&s6, 3); 
 
 // 遍历链表 
 for (int i = 0; i < LinkList_Length(list); ++i) { 
 Student *tmp = (Student *)LinkList_Get(list, i); 
 if (tmp == NULL) { 
 return 0; 
 } 
 printf("age: %dn", tmp->age); 
 } 
 
 // 删除链表结点 
 while (LinkList_Length(list)) { 
 Student *tmp = (Student *)LinkList_Delete(list, 0); 
 if (tmp == NULL) { 
 return 0; 
 } 
 printf("age: %dn", tmp->age); 
 } 
 
 LinkList_Destroy(list); 
 
 return 0; 
} 

优点:

  • 无需一次性定制链表的容量;
  • 插入和删除操作无需移动数据元素。

    缺点:

    • 数据元素必须保存后继元素的位置信息;
    • 获取指定数据的元素操作需要顺序访问之前的元素。

      工程详情:Github