亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > C++ > 正文

解析C++的線性表鏈式存儲設計與相關的API實現

2020-05-23 14:06:55
字體:
來源:轉載
供稿:網友
這篇文章主要介紹了解析C++中的線性表鏈式存儲設計與相關的API實現,文中的實例很好地體現了如何創建和遍歷鏈表等基本操作,需要的朋友可以參考下
 

基本概念
鏈式存儲定義:
為了表示每個數據元素與其直接后繼元素之間的邏輯關系,每個元素除了存儲本身的信息外,還需要存儲指示其直接后繼的信息。

C++,鏈式C++,鏈式

表頭結點:
鏈表中的第一個結點,包含指向第一個數據元素的指針以及鏈表自身的一些信息。
數據結點:
鏈表中代表數據元素的結點,包含指向下一個數據元素的指針和數據元素的信息。
尾結點:
鏈表中的最后一個數據結點,其下一元素指針為空,表示無后繼。

鏈表技術領域推演

C++,鏈式

鏈表鏈式存儲_api實現分析:
在C語言中可以用結構體來定義鏈表中的指針域,鏈表中的表頭結點也可以用結構體實現;

C++,鏈式

C++,鏈式

帶頭結點、位置從0的單鏈表;
返回鏈表中第3個位置處,元素的值。

LinkListNode* LinkList_Get(LinkList* list, int pos) {  if (list == NULL || pos < 0 || pos >= LinkList_Length(list)) {  return NULL;  }  TLinkList *tList = NULL;  tList = (TLinkList *)list;  LinkListNode *cur = NULL;  cur = &(tList->header);   for (int i = 0; i < pos; ++i) {  cur = cur->next;  }   return cur->next; } 

返回第三個位置的。
移動pos次以后,當前指針指向哪里?
答案:指向位置2,所以需要返回 ret = current->next。
 
備注:循環遍歷時
遍歷第1次,指向位置0;
遍歷第2次,指向位置1;
遍歷第3次,指向位置2;
遍歷第n次,指向位置n-1。

刪除元素:

C++,鏈式

代碼實例:

 linklist.h  

#ifndef _MYLINKLIST_H_ #define _MYLINKLIST_H_  typedef void LinkList;  typedef struct _tag_LinkListNode {  struct _tag_LinkListNode* next; }LinkListNode;  LinkList* LinkList_Create();  void LinkList_Destroy(LinkList* list);  void LinkList_Clear(LinkList* list);  int LinkList_Length(LinkList* list);  int LinkList_Insert(LinkList* list, LinkListNode* node, int pos);  LinkListNode* LinkList_Get(LinkList* list, int pos);  LinkListNode* LinkList_Delete(LinkList* list, int pos);  #endif 


linklist.cpp  
  

#include <iostream> #include <cstdio> #include "linklist.h"  using namespace std;  typedef void LinkList;  typedef struct _tag_LinkList {  LinkListNode header;  int length; }TLinkList;  LinkList* LinkList_Create() {  TLinkList *tmp = NULL;   tmp = (TLinkList *)malloc(sizeof(TLinkList));  if (tmp == NULL) {  printf("function LinkList_Create() err./n");  return NULL;  }  memset(tmp, 0, sizeof(TLinkList)); // 初始化為空鏈表   return tmp; }  void LinkList_Destroy(LinkList* list) {  if (list == NULL) {  return;  }  free(list);   return; }  void LinkList_Clear(LinkList* list) {  if (list == NULL) {  return;  }  TLinkList *tList = NULL;  tList = (TLinkList *)list;  tList->header.next = NULL;  tList->length = 0;   return; }  int LinkList_Length(LinkList* list) {  if (list == NULL) {  return -1;  }  TLinkList *tList = NULL;  tList = (TLinkList *)list;   return tList->length; }  int LinkList_Insert(LinkList* list, LinkListNode* node, int pos) {  if (list == NULL || node == NULL || pos < 0) {  return -1;  }  TLinkList *tList = NULL;  tList = (TLinkList *)list;  LinkListNode *cur = NULL;  cur = &(tList->header);   // 對pos的容錯處理,如果pos過大,改為最后面  if (pos > LinkList_Length(list)) {  pos = LinkList_Length(list);  }   // 移動到需要插入的位置  for (int i = 0; i < pos; ++i) {  cur = cur->next;  }   // 插入  node->next = cur->next;  cur->next = node;   ++tList->length;   return 0; }  LinkListNode* LinkList_Get(LinkList* list, int pos) {  if (list == NULL || pos < 0 || pos >= LinkList_Length(list)) {  return NULL;  }  TLinkList *tList = NULL;  tList = (TLinkList *)list;  LinkListNode *cur = NULL;  cur = &(tList->header);   for (int i = 0; i < pos; ++i) {  cur = cur->next;  }   return cur->next; }  LinkListNode* LinkList_Delete(LinkList* list, int pos) {  if (list == NULL || pos < 0 || pos >= LinkList_Length(list)) {  return NULL;  }  TLinkList *tList = NULL;  tList = (TLinkList *)list;  LinkListNode *cur = NULL;  cur = &(tList->header);   for (int i = 0; i < pos; ++i) {  cur = cur->next;  }   LinkListNode *ret = NULL;  ret = cur->next;   // 刪除結點  cur->next = ret->next;   --tList->length;   return ret; } 


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: %d/n", tmp->age);  }   // 刪除鏈表結點  while (LinkList_Length(list)) {  Student *tmp = (Student *)LinkList_Delete(list, 0);  if (tmp == NULL) {  return 0;  }  printf("age: %d/n", tmp->age);  }   LinkList_Destroy(list);   return 0; } 

優點:

  • 無需一次性定制鏈表的容量;
  • 插入和刪除操作無需移動數據元素。

缺點:

  • 數據元素必須保存后繼元素的位置信息;
  • 獲取指定數據的元素操作需要順序訪問之前的元素。

工程詳情:Github



發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
九九精品在线观看| 久久躁狠狠躁夜夜爽| 亚洲精品国偷自产在线99热| 欧美国产一区二区三区| 国产视频精品免费播放| 国产91精品网站| 久久夜色精品国产| 欧美午夜电影在线| 一本色道久久综合狠狠躁篇怎么玩| 97视频在线观看网址| 91免费福利视频| 亚洲欧美日韩一区二区在线| 韩曰欧美视频免费观看| 色婷婷成人综合| 91在线免费观看网站| 亚洲精品在线观看www| 亚洲乱码国产乱码精品精天堂| 日韩免费在线免费观看| 久久久久久久久久久免费精品| 在线精品国产成人综合| 国产精品美女无圣光视频| 欧美日本中文字幕| 国产欧美日韩亚洲精品| 午夜精品视频在线| 九九热最新视频//这里只有精品| 精品亚洲一区二区三区在线播放| 伊人成人开心激情综合网| 欧美精品999| 欧美性猛交xxxx免费看漫画| 另类专区欧美制服同性| 精品亚洲一区二区| 91影院在线免费观看视频| 国产精品视频网址| 亚洲欧美综合另类中字| 国产欧美在线播放| 国产精品免费一区豆花| 欧美亚洲国产成人精品| 欧美亚洲在线播放| 国产欧美日韩视频| 日韩免费观看视频| 91精品国产成人www| 欧美日韩精品在线观看| 欧美日韩人人澡狠狠躁视频| 欧美日韩亚洲系列| 国模精品视频一区二区三区| 正在播放欧美视频| 亚洲综合社区网| 精品久久久久久久久久ntr影视| 26uuu久久噜噜噜噜| 国产精品旅馆在线| 亚洲国产日韩欧美在线动漫| 欧美精品18videosex性欧美| 国产精品手机播放| 国产精品美女主播| 国产精品夫妻激情| 91精品国产综合久久香蕉最新版| 国产视频精品一区二区三区| 国产成人精彩在线视频九色| 欧美激情视频一区二区| 日韩av免费在线看| 亚洲欧美日韩国产成人| 日韩高清av一区二区三区| 亲子乱一区二区三区电影| 成人免费网视频| 一本色道久久88亚洲综合88| 免费91在线视频| 国产精品青草久久久久福利99| 91久久国产精品| 亚洲综合小说区| 日韩美女视频在线观看| 国产精品视频yy9099| 国产成人av在线播放| 欧美视频第一页| 国产精品成人观看视频国产奇米| 亚洲色图第三页| 粉嫩av一区二区三区免费野| 在线午夜精品自拍| 91精品国产综合久久香蕉922| 日韩综合视频在线观看| 国产精品成人一区二区| 亚洲国产天堂久久综合| 国产福利视频一区| 国产精品美女主播| 久久精品视频网站| 国产日韩av在线播放| 日韩av片永久免费网站| 精品中文字幕久久久久久| 久热在线中文字幕色999舞| 成人美女av在线直播| 亚洲视频欧洲视频| 亚洲国产第一页| 成人午夜在线视频一区| 欧美视频专区一二在线观看| 日韩在线视频网站| 亚洲欧美中文字幕| 欧美一二三视频| 国产成人综合精品在线| 国产欧美一区二区三区久久| 国产一区二区在线免费视频| 久久久久久97| 亚洲男人的天堂在线| 色av吧综合网| 欧美一级bbbbb性bbbb喷潮片| 国产精品久久久久9999| 懂色av一区二区三区| 中文字幕免费精品一区高清| 国产亚洲人成a一在线v站| 欧美精品久久一区二区| 4388成人网| 欧美色欧美亚洲高清在线视频| 26uuu另类亚洲欧美日本一| 欧美一级视频在线观看| 国产精品主播视频| 一区二区三区国产视频| 日韩免费在线视频| 久久视频在线看| 亚洲理论在线a中文字幕| 92国产精品久久久久首页| 成人免费黄色网| 九色91av视频| 国产精品男女猛烈高潮激情| 裸体女人亚洲精品一区| 中国china体内裑精亚洲片| 国产精品欧美久久久| 欧美成人午夜免费视在线看片| 国产精品视频成人| 国模精品视频一区二区| 亚洲精品免费av| 91亚洲国产成人精品性色| 久久国产精品久久久久久| 91精品国产九九九久久久亚洲| 中文字幕亚洲无线码a| 国产欧美日韩精品在线观看| 欧美性猛交xxxx黑人猛交| 欲色天天网综合久久| 欧美日韩精品在线观看| 国产成人精品在线观看| 精品久久中文字幕| 亚洲欧美激情在线视频| 亚洲在线免费观看| 中文字幕在线看视频国产欧美| 日韩hd视频在线观看| 国产专区欧美专区| 麻豆一区二区在线观看| 日韩美女视频中文字幕| 欧美成人在线免费视频| 日韩中文字幕视频| 国产精品视频永久免费播放| 麻豆乱码国产一区二区三区| 成人国产精品一区二区| 亚洲男人天堂2023| 亚洲欧美中文另类| 激情成人中文字幕| 日韩日本欧美亚洲| 国产精品扒开腿做爽爽爽视频| 久久综合亚洲社区| 亚洲欧美日韩久久久久久| 日韩成人小视频| 亚洲激情在线视频| 欧美激情视频免费观看| 欧洲日本亚洲国产区| 久久视频在线看| 国产精品久久久久久一区二区| 欧美日韩亚洲精品内裤|