单链表
链表可用于存储数据,在嵌入式开发时会经常用到,下面使用以前做过的例子记录一下数据结构中单链表的实现的增删改查。
#include <stdlib.h>
#include <stdio.h>
//初始化结构体
typedef struct linklist{
int id;//信息
struct linklist *next; //指针域
}Node; //Node 是struct linklist结构体的别名
/*单链表的增、删、改、查*/
//初始化带头结点的单链表
Node* init_node(void)
{
//创建新节点,并且为它申请堆内存
Node* head = malloc(sizeof(Node)); //已创建的堆内存由程序员手动释放,free
head->id = 0x00; //新节点的值指向0
head->next = NULL; //新节点的指针域指向空
return head; //返回头节点
}
//插入节点 pos表示节点要插入的位置
int insert_node(Node* node,int pos,int id)
{
//为插入的节点申请内存
Node* new = (Node*)malloc(sizeof(Node)); //(Node*)可要可不要
int i = 1;
//如果插入的节点(new)与当前节点(node)(即new节点插入后的前一个节点)不为空,与节点数大于或者等于1个,
if((node != NULL) && (new != NULL) && (pos>=1))
{
for(i;i< pos;i++)
{
node = node->next; //遍历节点,找到当前节点
}
new->next = node->next; //将新节点指向当前节点指向的区域(若只有头节点,node->next=NULL)?
new->id = id;
node->next = new; //当前节点指向新节点
return 0;
}else
return -1;
}
//删除节点
int delete_node(Node* head,int pos)
{
int i=1;
//让list这个结构体指针指向空
Node* list = NULL;
if((head != NULL) && (pos >= 1))
{
/*新建一个结构体指针来指向头结点,node 就是表头节点
?用current这个指针来遍历,找到当前节点 */
Node* current = head;
//当i<pos的时候,不断的遍历,就是不断往下查找,直找到要删除的节点的上一个节点
//pos就是节点所在的位置,比如删除第4节点,pos就是4,而current则会指向位置在3的节点。
for(i;i<pos;i++)
{
current = current->next;
}
list = current->next; //当前节点指向要删除的节点
current->next = list->next; //当前节点指向被删除节点的下一个节点(比如1->2->3)现在把2删除了,需要把1指向3
return 0;
}else
return -1;
}
//查找节点
Node* find_node(Node* head,int pos)
{
int i = 1;
Node* list = NULL;
if((head != NULL) && (pos >= 1))
{
//使指针p指向传入的头结点
Node* p = head;
//遍历找到要查找节点的上一个节点
for(i;i<pos;i++)
{
p = p->next;
}
//p的下一个节点就是要查找的节点
list = p->next;
//返回要查找的节点
return list;
}
return NULL;
}
//获取链表长度
int length_list(Node* node)
{
int count = 0;
//遍历
while(1)
{
//如果节点的指针指向空,说明已经遍历到最后一个节点
if(node->next == NULL)
break;
count++;
node = node->next;
}
//返回节点的数目
return count;
}
//显示链表中所有节点
int display_list(Node* list)
{
int i;
//依次遍历节点
for(i = 1; i <= length_list(list);i++)
{
//将找到的节点的id打印出来
Node* list_d=find_node(list,i);
printf("id is %d\n",list_d->id);
}
}
int main()
{
int i;
struct linklist * list = init_node();
insert_node(list,1,1);
insert_node(list,2,2);
insert_node(list,3,3);
insert_node(list,4,4);
printf("新增节点后的链表:\n");
display_list(list);
printf("删除节点3后的链表:\n");
delete_node(list,3);
display_list(list);
return 0;
}