单链表的构造和使用

单链表

  链表可用于存储数据,在嵌入式开发时会经常用到,下面使用以前做过的例子记录一下数据结构中单链表的实现的增删改查。

#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;
}


 

 

  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值