(C语言)初识链表

简介: (C语言)初识链表

1利用链表打印1-10的元素

#include<stdio.h>
//定义一个结构体变量
//既存放一个变量,又把首个节点的地址存入,方便之后通过head的地址找其他变量的地址
typedef struct  node
{
  int a;
  struct node* next;
};
int main()
{
  struct node head, *p, *q;
  int i, n;
  q = &head;//q取首元素地址
  for (i = 1; i <= 10; i++)//设置循环
  {
        malloc函数是c语言的函数,指申请一个你需要的变量大小的空间,单位是字节
  p = malloc(sizeof(struct node));//空间地址是随机的
  p->a = i;//将i的值存入p的a元素里
  q->next = p;//将p的地址存入q的next元素里
  q = p;再将p的地址覆盖在q上
  }
  p->next = NULL;//设置循环停止条件
  p = head.next;
  while (p != NULL)用while循环打印
  {
  printf("%d ", p->a);
  p = p->next;
  }
  return 0;
}


2,将链表的第二位插入一个0;

#include<stdio.h>
struct  node
{
  int a;
  node* next;
};
int main ()
{
  node head,*p,*q;
  int i,n;
  q=&head;
  for(i=1;i<=10;i++)
  {
  p=new node;
  p->a=i;
  q->next=p;
  q=p;
  }
  p->next=NULL;
  n=5;
  p=&head;
  for(i=0;i<n;i++) p=p->next;
  q=new node;
  q->a=0;
  q->next=p->next;
  p->next=q;
  p=head.next;
  while(p!=NULL)
    {
      printf("%d ",p->a);
   q=p->next;
   delete p;
   p=q;
    }
  return 0;
}


小编是在DEV上写的,因为好像vs中new和delete要c++函数。


效果

1669434860374.jpg


3删除第二个元素

struct  node
{
  int a;
  node* next;
};
int main ()
{
  node head,*p,*q;
  int i,n;
  q=&head;
  for(i=1;i<=10;i++)
  {
  p=new node;
  p->a=i;
  q->next=p;
  q=p;
  }
  p->next=NULL;
  n=2;
  p=&head;
  for(i=1;i<n;i++) p=p->next;
  q=p->next;
  p->next=q->next;
  p=head.next;
  delete q;
  while(p!=NULL)
    {
      printf("%d ",p->a);
   q=p->next;
   delete p;
   p=q;
    }
  return 0;
}

输出效果

1669434809274.jpg

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