链表的插入、删除和查询—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);
}

相关文章
|
5天前
|
C语言
对链表使用插入排序的C语言实现示例
对链表使用插入排序的C语言实现示例
|
5天前
|
存储 编译器 C语言
【数据结构】C语言实现带头双向循环链表万字详解(附完整运行代码)
【数据结构】C语言实现带头双向循环链表万字详解(附完整运行代码)
11 0
|
5天前
|
C语言
C语言循环链表讲解
C语言循环链表讲解
21 0
|
5天前
|
存储 C语言
C语言线性链表讲解
C语言线性链表讲解
21 0
|
5天前
|
存储 C语言
C语言双向链表讲解
C语言双向链表讲解
19 0
|
5天前
|
C语言
基于链表实现的链式管理系统(C语言课设)
基于链表实现的链式管理系统(C语言课设)
|
5天前
|
C语言
链接未来:深入理解链表数据结构(二.c语言实现带头双向循环链表)
链接未来:深入理解链表数据结构(二.c语言实现带头双向循环链表)
33 0
|
5天前
|
存储 算法 C语言
C语言线性链表
【4月更文挑战第10天】C程序线性链表
21 0
|
5天前
|
C语言
C语言之生肖、年龄、星座查询
C语言之生肖、年龄、星座查询
|
5天前
|
存储 C语言
C语言之单链表的实现以及链表的介绍
C语言之单链表的实现以及链表的介绍