单链表插入元素之尾插法
2019-04-06 19:24
225 查看
版权声明:如有侵权,请及时删除,引用请标明出处,联系:2195971474@qq.com https://blog.csdn.net/khqxf/article/details/89059246
尾插法
#include<stdio.h> #include<stdlib.h> #include<string.h> void getinput(struct Book *book); void addBook(struct Book **library); void printLibrary(struct Book *library); void releaseLibrary(struct Book **library); struct Book { char title[128]; char author[40]; struct Book *next; }; void getinput(struct Book *book) { printf("\n请输入书名:"); scanf("%s",book->title); //scanf中不要有换行符 printf("\n请输入作者:"); scanf("%s",book->author); } void addBook(struct Book **library) //采用头插法,往链表中插入元素,library作为头指针,两层解引用,因为它是指向结构体指针的指针 { struct Book *book,*temp; book = (struct Book *)malloc(sizeof(struct Book)); //为要插入的元素动态申请一块内存空间 if(book == NULL) { printf("内存分配失败!\n"); exit(1); } getinput(book); //获取插入元素的内容 if(*library != NULL) //如果插入的不是NULL链表 { temp = *library; //定位单链表尾部的位置 while(temp!=NULL) { temp = temp->next; } //插入数据 temp->next = book; book->next = NULL; } else { *library = book; book->next = NULL; } } void printLibrary(struct Book *library) { struct Book *book; int count = 1; book = library; while(book!=NULL) { printf("\nBook%d:\n",count); printf("\n书名:%s\n",book->title); printf("\n作者:%s\n",book->author); book = book ->next; count++; } } void releaseLibrary(struct Book **library) { struct Book *temp; while(*library != NULL) { temp = *library; *library = (*library)->next; //考虑运算符的优先级,->的高于解引用*,故需要加括号。 free(temp); } } int main(void) { struct Book *library = NULL; int ch; while(1) { printf("\n请问是否需要输入书籍或者作者(Y/N): "); do { ch = getchar(); }while(ch!='Y'&&ch!='N'); if(ch=='Y') { addBook(&library); } else { break; } } printf("\n请问是否需要打印书籍信息(Y/N): "); do { ch = getchar(); }while(ch!='Y'&&ch!='N'); if(ch=='Y') { printLibrary(library); } else { releaseLibrary(&library); } return 0; }
执行结果:
上面的方式,每次插入新元素时,都会遍历整个链表,看是否到达链表尾部,才执行插入操作,效率低,改进的方式是在addBook()中引入一个静态的结构体指针,始终指向链表的尾部。
#include<stdio.h> #include<stdlib.h> #include<string.h> void getinput(struct Book *book); void addBook(struct Book **library); void printLibrary(struct Book *library); void releaseLibrary(struct Book **library); struct Book { char title[128]; char author[40]; struct Book *next; }; void getinput(struct Book *book) { printf("\n请输入书名:"); scanf("%s",book->title); //scanf中不要有换行符 printf("\n请输入作者:"); scanf("%s",book->author); } void addBook(struct Book **library) //采用头插法,往链表中插入元素,library作为头指针,两层解引用,因为它是指向结构体指针的指针 { struct Book *book; static struct Book *tail; //定义静态结构体指针,始终指向链表尾部 book = (struct Book *)malloc(sizeof(struct Book)); //为要插入的元素动态申请一块内存空间 if(book == NULL) { printf("内存分配失败!\n"); exit(1); } getinput(book); //获取插入元素的内容 if(*library != NULL) //如果插入的不是NULL链表 { //插入数据 tail->next = book; book->next = NULL; } else { *library = book; book->next = NULL; } tail = book; //保证tail指向链表尾部 } void printLibrary(struct Book *library) { struct Book *book; int count = 1; book = library; while(book!=NULL) { printf("\nBook%d:\n",count); printf("\n书名:%s\n",book->title); printf("\n作者:%s\n",book->author); book = book ->next; count++; } } void releaseLibrary(struct Book **library) { struct Book *temp; while(*library != NULL) { temp = *library; *library = (*library)->next; //考虑运算符的优先级,->的高于解引用*,故需要加括号。 free(temp); } } int main(void) { struct Book *library = NULL; int ch; while(1) { printf("\n请问是否需要输入书籍或者作者(Y/N): "); do { ch = getchar(); }while(ch!='Y'&&ch!='N'); if(ch=='Y') { addBook(&library); } else { break; } } printf("\n请问是否需要打印书籍信息(Y/N): "); do { ch = getchar(); }while(ch!='Y'&&ch!='N'); if(ch=='Y') { printLibrary(library); } else { releaseLibrary(&library); } return 0; }
相关文章推荐
- 输入一组整型元素序列,使用尾插法建立一个带有头结点的单链表。 ② 实现该线性表的遍历。 ③ 在该单链表的第i个元素前插入一个整数。 ④ 删除该单链表中的第i个元素,其值通过参数将其返回。 ⑤ 建立两个
- (2)单链表的操作 ① 输入一组整型元素序列,使用尾插法建立一个带有头结点的单链表。 ② 实现该线性表的遍历。 ③ 在该单链表的第i个元素前插入一个整数。 ④ 删除该单链表中的第i个元素,其值通过参数
- 队列用链表实现(建立,插入新元素,删除元素,读取元素,全部删除,全部读出,判断是否为空,清空)
- 2.单链表内元素的插入
- 链表的基本操作 (1)采用尾插法建立一个链表; (2)输入一个元素,在道表中查找该元素是否存在,请给出相关信息; (3)将链表中的元素进行就地逆置。
- 双向链表-插入元素
- 往有序链表的插入元素使原链表依旧有序
- 单链表 初始化 创建 头插法 尾插法 插入 删除 查找 合并 长度
- C/C++,数据结构实现两个链表的合并(尾插法建立单链表,求链表长度,直接插入排序)
- 数据结构:头插法、尾插法创建单链表,求链表长度、查找、插入、删除、合并
- 链表遍历打印 翻转及 插入元素
- 链表的基本操作(创建,查找指定位置元素,删除指定元素,插入,倒置,去重,求集合的差,分别交换结点与交换结点值实现的冒泡排序,将两个有序链表合并成一个有序链表)c语言实现
- 双链表元素的删除和插入(VS2010测…
- 单链表的创建(头插尾插),表长,输出,插入,删除,查找,逆置,分解长两个链表(奇数偶数链表),查找倒数第k个元素,产出相同元素
- C语言——单链表初始化、求表长、读表元素、插入元素
- 数据结构—链表元素的删除和插入
- 向带头结点的双向链表中第i个位置之前插入元素e
- C/C++,数据结构实现两个链表的合并(尾插法建立单链表,求链表长度,直接插入排序)
- 尾插法插入链表节点
- 往有序单循环链表的插入元素使原链表依旧有序