链表的创建,搜索,删除,释放

本文详细介绍了一种使用C语言实现链表的方法,包括链表的创建、搜索、删除及遍历等核心功能。通过具体代码示例,展示了如何动态分配内存创建链表节点,以及如何进行链表的基本操作。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

#include <stdio.h>
#include <stdlib.h>
/* 创建一个长度为N的链表 */

//链表的存储模型
typedef struct creation{
  int value;
  struct creation *next;
} creat;

//保存链表的头尾结点
typedef struct _list{
  creat *head;
  creat *tail;
} List;

void creat_node (List* pList,int n);//创建链表
void search_link_number(List *pList, int number);//搜索链表
void delete_node(List *pList, int number);//删除结点
void search_all_link(List *pList);//遍历结点
void free_all_link(List *pList);//清除链表

int main()
{
  int n;//链表的长度
  int number;
  List list;
  list.head = list.tail = NULL;
  printf("输入要创建的结点个数:");
  scanf("%d",&n);
  creat_node(&list,n);
  printf("输入要查找的数字:");
  scanf("%d", &number);
  search_link_number(&list, number);
  printf("输入要删除的数字:");
  scanf("%d", &number);
  delete_node(&list, number);
  printf("开始检查整个链表并输出链表数据:");
  search_all_link(&list);
  printf("清除链表\n");
  free_all_link(&list);
  return 0;
}
/* 创建链表 */
void creat_node(List* pList,int n){
  int number;//要存到结点中的数据
  if (!n){
      printf("不能创建空结点");
  }
  else{
      creat *p = (creat *)malloc(sizeof(creat));//分配内存
      printf("输入结点数据:");
      scanf("%d", &number);//创建一个结点
      p->value = number;
      p->next = NULL;
      pList->head = p;
      pList->tail = pList->head;
      while(--n){//当n>1时
        creat *q = (creat *)malloc(sizeof(creat));
        printf("输入结点数据:");
        scanf("%d", &number);
        q->value = number;
        q->next = NULL;
        pList->tail->next = q;
        pList->tail = q;
    }
  }
}
/* 搜索链表 */
void search_link_number(List*pList,int number){
  creat *p;
  int cnt = 1;
  int correct_number = 1;
  for (p = pList->head; p; p=p->next,cnt++){
    if (p->value == number){
      printf("找到啦,在第%d个结点!\n", cnt);
      correct_number = 0;
    }
  }
  if(correct_number){
    printf("没找到呀,猪头,没记错吧!\n");
  }
}
/* 删除链表 */
void delete_node(List*pList, int number){
  creat *p;
  creat *q;
  int cnt = 0;
  int correct_number = 1;
  for (q = NULL ,p=pList->head; p; q = p, p = p->next, cnt++)
  {
    if (p->value == number){
      if(q){
        q->next = p->next;
        correct_number = 0;
      }else{
        pList->head = p->next;
        correct_number = 0;
      }
    }
    free(p);
    printf("已删除结点!\n");
    break;
  }
  if(correct_number){
    printf("没找到呀,猪头,没记错吧!\n");
  }
}
/* 遍历结点 */
void search_all_link(List *pList){
  creat *p;
  for (p = pList->head; p;p=p->next){
    printf("%d ", p->value);
  }
  printf("检查结束!\n");
}
/* 清除链表 */
void free_all_link(List *pList){
  creat *p;
  creat *q;
  for (p = pList->head; p;p=q){
    q = p->next;
    free(p);
  }
}


评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值