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

相关文章
|
4月前
|
存储 缓存 前端开发
【数据结构/C语言】深入理解 双向链表
【数据结构/C语言】深入理解 双向链表
|
25天前
|
存储 C语言
C语言程序设计核心详解 第九章 结构体与链表概要详解
本文档详细介绍了C语言中的结构体与链表。首先,讲解了结构体的定义、初始化及使用方法,并演示了如何通过不同方式定义结构体变量。接着,介绍了指向结构体的指针及其应用,包括结构体变量和结构体数组的指针操作。随后,概述了链表的概念与定义,解释了链表的基本操作如动态分配、插入和删除。最后,简述了共用体类型及其变量定义与引用方法。通过本文档,读者可以全面了解结构体与链表的基础知识及实际应用技巧。
|
1月前
|
存储 测试技术 C语言
C语言实现链表的各种功能
本文详细介绍了如何使用C语言实现链表的各种功能,包括链表节点结构的定义与操作函数的实现。链表作为一种常用的数据结构,具有节点自由插入删除、动态变化等特点。文中通过`link_list.h`和`link_list.c`两个文件,实现了链表的初始化、插入、删除、查找、修改等核心功能,并在`main.c`中进行了功能测试。这些代码不仅展示了链表的基本操作,还提供了丰富的注释帮助理解,适合作为学习链表的入门资料。
|
25天前
|
存储 算法 C语言
C语言手撕实战代码_循环单链表和循环双链表
本文档详细介绍了用C语言实现循环单链表和循环双链表的相关算法。包括循环单链表的建立、逆转、左移、拆分及合并等操作;以及双链表的建立、遍历、排序和循环双链表的重组。通过具体示例和代码片段,展示了每种算法的实现思路与步骤,帮助读者深入理解并掌握这些数据结构的基本操作方法。
|
20天前
|
C语言
C语言里的循环链表
C语言里的循环链表
|
2月前
|
存储 C语言
【数据结构】c语言链表的创建插入、删除、查询、元素翻倍
【数据结构】c语言链表的创建插入、删除、查询、元素翻倍
【数据结构】c语言链表的创建插入、删除、查询、元素翻倍
|
3月前
|
存储 数据管理 C语言
C语言实战 | 使用链表完成“贪吃蛇”游戏
【7月更文挑战第1天】整体思维,即系统思维,强调以整体视角理解事物。在编程中,结构体体现这种思想,将相关变量打包处理。示例展示了如何用链表而非数组实现“贪吃蛇”游戏,链表提供了更灵活的动态数据管理。一系列代码图片详细描绘了链表结构体在游戏中的应用,包括节点定义、移动、碰撞检测等,凸显了使用链表的优势和代码的清晰组织。
36 0
C语言实战 | 使用链表完成“贪吃蛇”游戏
|
4月前
|
存储
数据结构——双向链表(C语言版)
数据结构——双向链表(C语言版)
29 2
|
4月前
|
算法 C语言
数据结构——单向链表(C语言版)
数据结构——单向链表(C语言版)
41 2
|
5月前
|
存储 C语言 Python
下一篇
无影云桌面