当前位置: 首页 > news >正文

做公司网站按年收费山西省吕梁市有哪些县

做公司网站按年收费,山西省吕梁市有哪些县,分享社交电商十大平台,怎么写网站建设维护推广合同线性表的链式存储结构 概念 将线性表 L (a0, a1, … , an-1)中各元素分布在存储器的不同存储块,成为结点,通过地址或指针建立元素之间的联系。 结点的 data 域存放数据元素 ai ,而 next 域是一个指针,指向 ai 的直接后继 ai1 …

线性表的链式存储结构

概念

将线性表 L = (a0, a1, … , an-1)中各元素分布在存储器的不同存储块,成为结点,通过地址或指针建立元素之间的联系。
在这里插入图片描述
结点的 data 域存放数据元素 ai ,而 next 域是一个指针指向 ai 的直接后继 ai+1 所在的结点

  • 下图中的首元结点(头结点) A 的 data 不重要next 域指向链表的真正的第一个结点头结点的作用也是为了指明哪个结点是链表的第一个结点。

  • 最后一个结点的 next 域,也就是下图中最后一个结点的那个 ^ 代表的是 NULL

在这里插入图片描述

结点类型描述

typedef struct node
{data_t data; //结点的数据域struct node *next; //结点的后继指针域
}listnode, *linklist;

则有:

listnode A;
linklist p = &A;

结点声明

在这里插入图片描述
设 P 指向链表中结点 ai
在这里插入图片描述
获取 ai,写作:p->data
获取 ai+1,写作:p->next->data

若指针 p 的值为 NULL,则它不指向任何结点,此时 p->datap->next 是非法操作。

可调用 C 语言中 malloc() 函数向系统申请结点的存储空间:

linklist p;
p = (linklist)malloc(sizeof(listnode));

则创建一个类型为 linklist 的结点,且该结点的地址已存入指针变量 p 中。

建立单链表

  • 目标:建立单链表
  • 思路:
    1、给头结点分配空间然后判空
    2、初始化头结点(H->data,H->next)
    3、返回头结点
  • 代码:
linklist list_create()
{linklist H; //头结点//分配空间并判空if ((H = (linklist)malloc(sizeof(listnode))) == NULL){printf("malloc H failed!\n");return NULL;}//初始化头结点H->data = 0;H->next = NULL;//返回头结点return H;
}

链表尾部插入节点

  • 目标:向单链表的尾部插入新的节点
  • 思路:
    1、建立新节点,给新节点分配空间并初始化
    2、定义指针指示插入节点的位置,这个位置的 next 为空,这样才能在 next 插入新节点,才能保证在链表的结尾插入节点 (从 H 开始,通过 q=q->next 遍历链表直到链表尾部
    3、在指针的 next 插入新节点
  • 代码:
int list_insert_tail(linklist H, data_t value)
{linklist p; //要插入的新节点 linklist q; //确定插入位置的指针//如果头结点为空那么以后的操作也没办法进行if (H == NULL){printf("H is NULL!\n");return -1;}//给新节点分配空间并判空if ((p = (linklist)malloc(sizeof(listnode))) == NULL){printf("malloc p failed!\n");return -1;}//初始化新节点p->data = 0;p->next = value;q = H;//确定插入节点的位置while (q->next){q = q->next;}//在链表尾部插入节点q->next = p;return 0;
}

根据下标查找节点

  • 目标:根据位置获取链表中的节点
  • 思路:
    1、判头结点是否为空,判下标是否合法;
    2、定义遍历链表的指针和 i 遍历链表直到找到指定位置(注意遍历完链表也没有找到指定节点的情况);
    3、返回要查找的节点或空节点(未找到的情况)
  • 代码:
linklist list_get(linklist H, int pos)
{linklist p; //遍历用指针int i; //遍历用标记if (H == NULL){printf("H is NULL!\n");return NULL;}if (pos < 0){printf("pos is invalid\n");return NULL;}p = H;i = -1;while (i < pos){p = p->next; //指针p向下移动//已经遍历完链表但没找到这个位置则breakif (p == NULL){break;}i++; //i迭代}return p;
}

在链表指定位置插入新节点

  • 目标:给定链表、位置和新节点的值将这个新节点插入到链表的指定位置
  • 思路:
    1、判头节点是否为空,位置是否合法(初步)
    2、通过指针和 i 遍历链表找到这个要插入节点的前一个节点的位置,让指针指向这个节点
    3、通过改变指针指向插入这个新节点
  • 代码:
int list_insert_between(linklist H, data_t value, int pos)
{linklist p; //遍历用指针linklist q; //新节点int i;//如果头结点为空那么以后的操作也没办法进行if (H == NULL){printf("H is NULL!\n");return -1;}//这种位置无效if (pos < -1){printf("H is invalid!\n");return -1;}//给新节点分配空间并判空if ((q = (linklist)malloc(sizeof(listnode))) == NULL){printf("malloc p failed!\n");return -1;}//初始化新节点q->next = NULL;q->data = value;//p从头结点开始遍历p = H;while (i < pos - 1) //注意这里是 pos - 1,一定要在循环结束时让指针指向指定位置的前一个节点{p = p->next;//i还没到pos指针指向节点就空了,证明给定的位置无效if (p == NULL){printf("the pos not found!\n");return -1;}i++;}//此时指针指向指定位置的前一个节点,通过改变指针指向插入新节点q->next = p->next;p->next = q;return 0;
}	

打印链表

  • 目标:打印链表节点
  • 思路:通过指针遍历链表并打印
  • 代码:
int list_show(linklist H) {linklist p;if (H == NULL) {printf("H is NULL\n");return -1;}p = H;while (p->next != NULL) {printf("%d ", p->next->data);p = p->next;}puts("");return 0;
}
http://www.yayakq.cn/news/800252/

相关文章:

  • 企业网站建设排名官网苏州代理注册公司哪家好
  • 网站开发的文献网站注册用户推广
  • 里水九江网站建设网站横幅广告怎么做
  • 免费外贸网站建设wordpress捐赠按钮
  • 仿站工具箱wordpress里面如何加载百度地图
  • 网站建设公司的选择丹徒网站建设策划
  • 做网站去哪个公司好专门做装修的网站有哪些
  • 网站过程建设小说小程序搭建
  • wordpress扒站教程网站建设项目前分析
  • 商城建站报价方案怎么把自己做的网站发布
  • 郑州个人网站建设怎么把自己做的网站放到公网上
  • 餐饮营销型网站案例分析wordpress页面加载慢
  • 网站开发要多少钱教育网站制作要多少钱
  • 永康网站设计做网站会遇到哪些问题
  • 高端自适应网站wordpress调用标签
  • 广东建设基金管理有限公司网站网站群建设存在的问题
  • 甘肃第九建设集团公司网站软件工程课程设计课程网站建设
  • 网站建设公司兴田德润在那里做h网站怎么才能安全
  • vue做的小网站如何做网站将数据上传
  • 营销型网站建设 ppt网站大专
  • 如何建一个自己的网站网页版梦幻西游周年庆攻略
  • 网页制作与设计站点应该怎么建网站建设培训班南宁
  • 加工厂做网站平顶山建设街小学网站
  • 信息型网站wordpress 编辑器 插件
  • 网页设计流程与步骤如何给自家网站做关键词优化
  • 公司网站需求有什么图片做视频的网站吗
  • 做网站大约需要多少钱展厅展示设计
  • 电子商城网站设计十款看免费行情的软件推荐
  • 上海工商网站做网站的版式会侵权吗
  • 河北网络公司网站建设网站怎么自己做优化