博客
关于我
C语言:链表的运用(二)
阅读量:328 次
发布时间:2019-03-04

本文共 2051 字,大约阅读时间需要 6 分钟。

链表的动态创建方法详解

前插法与尾插法的实现

在实际开发中,链表的动态创建通常采用前插法或尾插法。这种方法允许我们逐步构建链表,适用于需求不明确或数据插入顺序不确定的情况。

前插法实现

#include 
#include
struct Test { int data; struct Test *next;};void printLink(struct Test *head) { struct Test *p = head; while (p != NULL) { printf("%d ", p->data); p = p->next; } putchar('\n');}struct Test* creatFromHead(struct Test *head, struct Test *new) { if (head == NULL) { head = new; } else { new->next = head; head = new; } return head;}struct Test* creatLink(struct Test *head) { struct Test *new; while (1) { new = (struct Test *)malloc(sizeof(struct Test)); printf("Please input:\n"); scanf("%d", &new->data); if (new->data == 0) { free(new); break; } head = creatFromHead(head, new); } return head;}int main() { struct Test *p = NULL; p = creatLink(p); printLink(p); return 0;}

尾插法实现

#include 
#include
struct Test { int data; struct Test *next;};void printLink(struct Test *head) { struct Test *p = head; while (p != NULL) { printf("%d ", p->data); p = p->next; } putchar('\n');}struct Test* creatFromBehind(struct Test *head, struct Test *new) { struct Test *p = head; if (head == NULL) { head = new; return head; } while (p->next != NULL) { p = p->next; } p->next = new; return head;}struct Test* creatLink(struct Test *head) { struct Test *new; while (1) { new = (struct Test *)malloc(sizeof(struct Test)); printf("Please input:\n"); scanf("%d", &new->data); if (new->data == 0) { free(new); break; } head = creatFromBehind(head, new); } return head;}int main() { struct Test *p = NULL; p = creatLink(p); printLink(p); return 0;}

两种方法的对比

前插法和尾插法在实现上有所不同,但最终目标相同。前插法更直观,适合需要频繁插入新节点的场景,而尾插法在插入操作次数少的情况下表现更优。

选择建议

选择哪种方法取决于具体需求:

  • 频繁插入节点:前插法优于尾插法。
  • 插入次数少:尾插法更高效。

无论选择哪种方法,掌握两种实现方式都是有益的。

转载地址:http://enah.baihongyu.com/

你可能感兴趣的文章
Mysql 学习总结(88)—— Mysql 官方为什么不推荐用雪花 id 和 uuid 做 MySQL 主键
查看>>
Mysql 学习总结(89)—— Mysql 库表容量统计
查看>>
mysql 实现主从复制/主从同步
查看>>
mysql 审核_审核MySQL数据库上的登录
查看>>
mysql 导入 sql 文件时 ERROR 1046 (3D000) no database selected 错误的解决
查看>>
mysql 导入导出大文件
查看>>
MySQL 导出数据
查看>>
mysql 将null转代为0
查看>>
mysql 常用
查看>>
MySQL 常用列类型
查看>>
mysql 常用命令
查看>>
Mysql 常见ALTER TABLE操作
查看>>
MySQL 常见的 9 种优化方法
查看>>
MySQL 常见的开放性问题
查看>>
Mysql 常见错误
查看>>
mysql 常见问题
查看>>
MYSQL 幻读(Phantom Problem)不可重复读
查看>>
mysql 往字段后面加字符串
查看>>
mysql 快照读 幻读_innodb当前读 与 快照读 and rr级别是否真正避免了幻读
查看>>
MySQL 快速创建千万级测试数据
查看>>