链表的插入、删除和查询—C语言

简介: 链表的插入、删除和查询—C语言

单链表的插入、删除和查询:

程序代码:

#include<stdio.h>
#include<stdlib.h>
struct node
{
  int date;
  struct node *next;
};
int n;
typedef struct node LNode,*Link;
void creat(Link head,int n);
void insert(Link head,int i,int m);
void delet(Link head,int s);
void getelm(Link head,int k);
int main()
{
  Link head,t;
  int a,i,m,s,k;
  head=(Link)malloc(sizeof(LNode));
  head->next=NULL;
  printf("输入要输入元素的个数: \n");
  scanf("%d",&n);
  printf("元素是:\n");
  creat(head,n);
  t=head->next;
  printf("创建的链表:\n");
  while(t!=NULL)
  {
    printf("%d ",t->date);
    t=t->next;
  } 
  printf("\n输入要插入元素的位置、元素 :\n");
  scanf("%d %d",&i,&m);
  insert(head,i,m);
  printf("插入后的链表是: \n");
  t=head->next;
  while(t!=NULL)
  {
    printf("%d ",t->date);
    t=t->next;
  }
  printf("\n输入要删除元素的位置 :\n");
  scanf("%d",&s);
  delet(head,s);
  printf("删除后的链表是:\n");
  t=head->next;
  while(t!=NULL)
  {
    printf("%d ",t->date);
    t=t->next;
  }
  printf("\n输入要查询元素的位置 :\n");
  scanf("%d",&k);
  printf("查询的元素是 :\n");
  getelm(head,k);
  return 0;
}
void creat(Link head,int n)
{
  Link p,rear=head;
  int a,i;
  for(i=0;i<n;i++)
  {
    scanf("%d",&a);
    p=(Link)malloc(sizeof(LNode));
    p->date=a;
    rear->next=p;
    rear=p;
  }
  rear->next=NULL;
}
void insert(Link head,int i,int m)
{
  Link q,p;
  int j=0;
  p=head;
  while(p!=NULL&&j<i-1)
  {
    j++;
    p=p->next;
  }
  q=(Link)malloc(sizeof(LNode));
  q->date=m;
  q->next=p->next;
  p->next=q;
}
void delet(Link head,int s)
{
  Link q,p;
  p=head;
  int j=0;
  while(p!=NULL&&j<s-1)
  {
    p=p->next;
    j++;
  }
  q=(Link)malloc(sizeof(LNode));
  q=p->next;
  p->next=q->next;
  free(q);
}
void getelm(Link head,int k)
{
  Link q,p;
  int j=0;
  p=head;
  while(p!=NULL&&j<k-1)
  {
    p=p->next;
    j++;
  }
  p=p->next;
  printf("%d\n",p->date);
}

双向链表的插入、删除和查询:

程序代码:

#include<stdio.h>
#include<stdlib.h>
struct node
{
  int date;
  struct node *next;
  struct node *prev;
};
typedef struct node LNode ,*Link;
void creat(Link head,int n);
void insert(Link head,int i,int m);
void delet(Link head,int s);
void getelm(Link head,int k);
int main()
{
  Link head,t;
  int n,i,a,m,s,k;
  head=(Link)malloc(sizeof(LNode));
  head->next=NULL;
  head->prev=NULL;
  printf("输入元素的个数 :\n");
  scanf("%d",&n);
  printf("元素是:\n");
  creat(head,n);
  t=head->next;
  printf("创建的双向链表是:\n");
  while(t!=NULL)
  {
    printf("%d ",t->date);
    t=t->next;
  }
  printf("\n插入的位置、元素: \n");
  scanf("%d %d",&i,&m);
  insert(head,i,m);
  printf("插入后的链表:\n");
  t=head->next;
  while(t!=NULL)
  {
    printf("%d ",t->date);
    t=t->next;
  }
  printf("\n要删除元素的位置:\n");
  scanf("%d",&s);
  delet(head,s);
  printf("输出删除后的链表:\n");
  t=head->next;
  while(t!=NULL)
  {
    printf("%d ",t->date);
    t=t->next;
  }
  printf("\n输入要查询元素的位置:\n");
  scanf("%d",&k);
  getelm(head,k);
  return 0;
  
}
void creat(Link head,int n)
{
  Link q,p;
  int i,a;
  q=head;
  for(i=0;i<n;i++)
  {
    scanf("%d",&a);
    p=(Link)malloc(sizeof(LNode));
    p->date=a;
    q->next=p;
    p->prev=q;
    q=p;
  }
  q->next=NULL;
}
void insert(Link head,int i,int m)
{
  Link q,p;
  int j=0;
  p=head;
  while(p!=NULL&&j<i-1)
  {
    p=p->next;
    j++;
  }
  q=(Link)malloc(sizeof(LNode));
  q->date=m;
  q->next=p->next;
  p->next=q;
} 
void delet(Link head,int s)
{
  Link q,p;
  int j=0;
  p=head;
  while(q!=NULL && j<s-1)
  {
    p=p->next;
    j++;
  }
  q=(Link)malloc(sizeof(LNode));
  q=p->next;
  p->next=q->next;
  free(q);
}
void getelm(Link head,int k)
{
  Link q,p;
  int j=0;
  p=head;
  while(p!=NULL && j<k-1)
  {
    p=p->next;
    j++;
  }
  p=p->next;
  printf("%d\n",p->date);
}

相关文章
|
3天前
|
存储 缓存 C语言
C语言:链表和数组有什么区别
C语言中,链表和数组是两种常用的数据结构。数组是一种线性结构,元素在内存中连续存储,通过下标访问,适合随机访问且大小固定的情况。链表由一系列不连续的节点组成,每个节点存储数据和指向下一个节点的指针,适用于频繁插入和删除操作的场景,链表的大小可以动态变化。
|
4天前
|
C语言
无头链表再封装方式实现 (C语言描述)
如何在C语言中实现无头链表的再封装,包括创建节点和链表、插入和删除操作、查找和打印链表以及销毁链表的函数。
11 0
|
4天前
|
C语言
C语言链式结构之有头单链表再封装写法
本文介绍了如何使用C语言对有头单链表进行封装,包括节点的创建、链表的初始化、数据的插入和删除,以及链表的打印等功能。
10 1
|
4天前
|
C语言
C语言结构体链式结构之有头单链表
文章提供了一个C语言实现的有头单链表的完整代码,包括创建链表、插入、删除和打印等基本操作。
13 1
|
4天前
|
测试技术 C语言
单链表之无头链表(C语言版)
本文详细介绍了使用C语言实现无头单链表的方法,包括节点和链表结构的定义、链表的创建与销毁、节点的插入与删除,以及链表的打印等功能。文章通过具体的代码示例,展示了如何在无头链表中进行头插法、尾插法、自定义位置插入和删除,以及如何清空和销毁链表。
13 0
单链表之无头链表(C语言版)
|
4月前
|
存储 缓存 前端开发
【数据结构/C语言】深入理解 双向链表
【数据结构/C语言】深入理解 双向链表
|
4天前
|
C语言
无头链表二级指针方式实现(C语言描述)
本文介绍了如何在C语言中使用二级指针实现无头链表,并提供了创建节点、插入、删除、查找、销毁链表等操作的函数实现,以及一个示例程序来演示这些操作。
10 0
|
1月前
|
存储 C语言
C语言程序设计核心详解 第九章 结构体与链表概要详解
本文档详细介绍了C语言中的结构体与链表。首先,讲解了结构体的定义、初始化及使用方法,并演示了如何通过不同方式定义结构体变量。接着,介绍了指向结构体的指针及其应用,包括结构体变量和结构体数组的指针操作。随后,概述了链表的概念与定义,解释了链表的基本操作如动态分配、插入和删除。最后,简述了共用体类型及其变量定义与引用方法。通过本文档,读者可以全面了解结构体与链表的基础知识及实际应用技巧。
|
1月前
|
存储 测试技术 C语言
C语言实现链表的各种功能
本文详细介绍了如何使用C语言实现链表的各种功能,包括链表节点结构的定义与操作函数的实现。链表作为一种常用的数据结构,具有节点自由插入删除、动态变化等特点。文中通过`link_list.h`和`link_list.c`两个文件,实现了链表的初始化、插入、删除、查找、修改等核心功能,并在`main.c`中进行了功能测试。这些代码不仅展示了链表的基本操作,还提供了丰富的注释帮助理解,适合作为学习链表的入门资料。
|
1月前
|
存储 算法 C语言
C语言手撕实战代码_循环单链表和循环双链表
本文档详细介绍了用C语言实现循环单链表和循环双链表的相关算法。包括循环单链表的建立、逆转、左移、拆分及合并等操作;以及双链表的建立、遍历、排序和循环双链表的重组。通过具体示例和代码片段,展示了每种算法的实现思路与步骤,帮助读者深入理解并掌握这些数据结构的基本操作方法。