一个简单的"单向链表"

unit Unit1;

interface

uses
  Windows, Messages, SysUtils, Variants, Classes, Graphics, Controls, Forms,
  Dialogs, StdCtrls;

type
  TForm1 = class(TForm)
    Button1: TButton;
    Button2: TButton;
    procedure FormCreate(Sender: TObject);
    procedure Button1Click(Sender: TObject);
    procedure Button2Click(Sender: TObject);
  end;

var
  Form1: TForm1;

implementation

{$R *.dfm}

type
  PMyRec = ^MyRec;  {把 PMyRec 定义为下面 MyRec 结构的指针类型}
  MyRec = record
    Name: string[8];
    Age : Word;
    Link: PMyRec;   {结构中同时包含同类型的指针, 用于链接其他同类结构}
  end;

var
  R1,R2,R3,R4: MyRec;

{把 R1、R2、R3、R4 够建成一个环环相扣的"链", 这就是一个简单的"链表"}
procedure TForm1.FormCreate(Sender: TObject);
begin
  R4.Name := '李四';
  R4.Age  := 16;
  R4.Link := nil;

  R3.Name := '张三';
  R3.Age  := 61;
  R3.Link := @R4;

  R2.Name := '钱二';
  R2.Age  := 24;
  R2.Link := @R3;

  R1.Name := '赵一';
  R1.Age  := 42;
  R1.Link := @R2;
end;

{现在 , 通过 R1 即可以访问整个链; 但这个链是单向的, 所以叫"单向链表"}   
procedure TForm1.Button1Click(Sender: TObject);
begin
  ShowMessage(R1.Name); {赵一}
  ShowMessage(R1.Link^.Name); {钱二}
  ShowMessage(R1.Link^.Link^.Name); {张三}
  ShowMessage(R1.Link^.Link^.Link^.Name); {李四}
end;

{通过结构指针读取数据可以省略 ^; 所以 Button1Click 可以简写为:}
procedure TForm1.Button2Click(Sender: TObject);
begin
  ShowMessage(R1.Name); {赵一}
  ShowMessage(R1.Link.Name); {钱二}
  ShowMessage(R1.Link.Link.Name); {张三}
  ShowMessage(R1.Link.Link.Link.Name); {李四}
end;

end.

在C语言中,**创建一个“空”的单向链表**实际上是指创建一个**没有数据节点**的链表结构,通常包括一个**头指针(head)**,它初始化为 `NULL`,表示链表为空。 --- ### ✅ 创建空单向链表的方法 创建空链表的关键在于初始化一个头指针,并将其指向 `NULL`,表示当前链表中没有任何节点。 --- ### ✅ 示例代码:创建一个空的单向链表 ```c #include <stdio.h> #include <stdlib.h> // 定义链表节点结构体 struct Node { int data; struct Node *next; }; int main() { // 创建一个链表:头指针初始化为 NULL struct Node *head = NULL; // 判断链表是否为空 if (head == NULL) { printf("链表为空\n"); } else { printf("链表不为空\n"); } return 0; } ``` --- ### ✅ 输出结果: ``` 链表为空 ``` --- ### 🔍 说明 - `struct Node *head = NULL;` 表示这是一个链表; - 当 `head == NULL` 时,表示链表中没有节点; - 后续可以动态插入节点,例如使用 `malloc` 创建新节点并连接到链表中。 --- ### 🧠 如何添加节点(可选拓展) 虽然你现在只是要创建一个链表,但我们可以简单演示一下如何向空链表中插入一个节点: ```c // 创建一个新节点 struct Node *newNode = (struct Node *)malloc(sizeof(struct Node)); if (newNode == NULL) { printf("内存分配失败\n"); return -1; } newNode->data = 100; newNode->next = NULL; // 将新节点作为头节点 head = newNode; // 再次判断链表是否为空 if (head == NULL) { printf("链表为空\n"); } else { printf("链表不为空,head->data = %d\n", head->data); } ``` --- ### ✅ 总结 | 操作 | 描述 | |------------------|----------------------------------| | 初始化空链表 | `struct Node *head = NULL;` | | 判断是否为空 | `if (head == NULL)` | | 添加节点 | 使用 `malloc` 创建节点并连接 | ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值