麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 學院 > 開發設計 > 正文

雙向鏈表

2019-11-11 04:49:28
字體:
來源:轉載
供稿:網友

代碼示例

/* function:雙向鏈表的基本操作 created by : xilong date: 2017.2.6*/#include "iostream"using namespace std;#define OK 1#define ERROR 0#define TRUE 1#define FALSE 0typedef double Elemtype;typedef int Status;typedef struct DNode{ Elemtype data; struct DNode *PRior; struct DNode *next;}DNode;typedef struct DNode *DLinkList;/* 功能:初始化一個雙向鏈表頭,并且創建一個雙向鏈表*/DLinkList DLinkList_Init(){ DLinkList head; DLinkList p, s; head = (DLinkList)malloc(sizeof(DLinkList)); head->next = head->prior = NULL; p = head; int flag = 1; Elemtype c; while (flag) { cin >> c; if (c != -99999) { s = (DLinkList)malloc(sizeof(DLinkList)); s->data = c; p->next = s; s->prior = p; s->next=NULL; p = s; } else { flag = 0; p->next = NULL; } } return head;}/* 功能:計算鏈表的長度*/int DLinkList_Length(DLinkList *head){ DLinkList p; p = *head; int count = 0; while (p->next != NULL) { count++; p = p->next; } return count;}/* 功能:插入結點*/Status DLinkList_Insert(DLinkList *head, int i, Elemtype e){ DLinkList pre, s; pre = *head; int k = 1; if (pre->next == NULL) { cout << "插入位置錯誤!" << endl; return ERROR; } if (i > DLinkList_Length(head)) { cout << "插入位置錯誤!" << endl; return ERROR; } while (pre->next != NULL && k < i) // 找到第 i-1 個位置 { pre = pre->next; k++; } //cout << pre->data << endl; s = (DLinkList)malloc(sizeof(DLinkList)); s->data = e; s->next = pre->next; s->prior = pre; pre->next->prior = s; pre->next = s; return OK;}/* 功能:從鏈表的頭部開始,正序打印*/Status DLinkList_Print(DLinkList *head){ DLinkList p; p = (*head)->next; if (p == NULL) { cout << "空鏈表!" << endl; return ERROR; } while (p != NULL) { cout << p->data << " "; p = p->next; } cout << endl; return OK;}/* 功能:從鏈表的尾開始逆序打印*/Status DLinkList_Print2(DLinkList *head){ DLinkList p; p = (*head)->next; while (p->next!= NULL) { p = p->next; } while (p != *head) { cout << p->data << " "; p = p->prior; } cout << endl; return OK;}void main(){ DLinkList head; cout << "開始輸入(這里是尾插法建表,輸入-99999結束建表)..........." << endl; head = DLinkList_Init(); cout << "從頭打印鏈表............................................." << endl; DLinkList_Print(&head); cout << "從尾部反向打印鏈表......................................." << endl; DLinkList_Print2(&head); cout << "鏈表的長度為..........."; cout << DLinkList_Length(&head) << endl; cout << "***********************************************************************" << endl; cout << "開始插入.................................................." << endl; int i, j; cout << "輸入插入的位置:" << endl; cin >> i; cout << "輸入插入的數字:" << endl; cin >> j; DLinkList_Insert(&head, i, j); cout << "從頭打印鏈表............................................." << endl; DLinkList_Print(&head); cout << "從尾部反向打印鏈表......................................." << endl; DLinkList_Print2(&head); cout << "鏈表的長度為..........."; cout << DLinkList_Length(&head) << endl; system("pause");}

程序截圖

這里寫圖片描述


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 午夜小视频免费观看 | 欧美 日本 在线 | 日韩大片在线永久观看视频网站免费 | www久久国产| 性爱免费视频 | www.99久 | 亚洲欧美在线视频免费 | 亚洲精品午夜国产va久久成人 | 国产精品久久久久久久久久久久午夜 | 偿还电影免费看 | 精品久久一区二区 | 依依成人精品视频 | 在线成人av观看 | av在线播放免费观看 | 午夜天堂在线 | 免费a视频在线观看 | 日本教室三级在线看 | 欧美成人一区二区视频 | 国产一级一片免费播放 | 中文字幕一区在线观看视频 | 日韩精品免费一区二区三区 | 色视频欧美 | 亚洲自拍第二页 | 特级毛片a级毛片100免费 | 亚洲导航深夜福利涩涩屋 | 亚洲综合视频网 | 全网免费毛片 | 在线a免费观看 | 99精品电影 | 亚州精品天堂中文字幕 | 久色精品 | 成人午夜免费观看 | 美女视频网站黄色 | 久久久www免费看片 亚洲综合视频一区 | 中午字幕无线码一区2020 | 中日韩乱码一二新区 | 色人阁五月天 | 91成人免费网站 | 国产精品视频导航 | 中国av免费在线观看 | 久久恋 |