c++ 如何用链表存取数据
由于单链表的每个结点都有一个数据域和一个指针域。所以,每个结点可以定义成一个记录。
其中,DATA数据元素,可以为你想要储存的任何数据格式,可以是数组,可以是int,甚至可以是结构体(这就是传说中的结构体套结构体)
NEXT为一个指针,其代表了一个可以指向的区域,通常是用来指向下一个结点,链表的尾部NEXT指向NULL(空),因为尾部没有任何可以指向的空间了
#include<iostream> using namespace std; struct Node{ int data; Node *next; }; Node *head, *p, *r; //r指向链表的当前最后一个结点,可以称为尾指针 int x; int main(){ cin>>x; head=new Node; //申请头结点 r=head; while(x!=-1){ //读入的数非-1 p=new Node; //否则,读入一个新结点 p->data=x; //把数据放入数据域 p->next=NULL; // 先把当前这个结点的指针域变为NULL r->next=p; //把新结点链接 接到前面的链表中(p可以认为是一个结点的头指针), r=p; //尾指针后移一个 cin>>x; } return 0; }
【写法2】
//声明节点结构 typedef struct Link{ int elem;//存储整形元素 struct Link *next;//指向直接后继元素的指针 }link; //创建链表的函数 link * initLink(){ link * p=(link*)malloc(sizeof(link));//创建一个头结点 link * temp=p;//声明一个指针指向头结点,用于遍历链表 //生成链表 for (int i=1; i<5; i++) { //创建节点并初始化 link *a=(link*)malloc(sizeof(link)); a->elem=i; a->next=NULL; //建立新节点与直接前驱节点的逻辑关系 temp->next=a; temp=temp->next; } return p; }
扫描二维码推送至手机访问。
版权声明:本文由青少年编程知识记录发布,如需转载请注明出处。