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

吉林省建设安全信息网站外贸网站案例

吉林省建设安全信息网站,外贸网站案例,酒店网站开发方案,有没有免费的crm系统一、链表之单向链表 前面我们使用顺序储存结构实现的顺序表,虽然查询的时候很快,但在进行元素的增加或者删除的时候:比较麻烦,需要你去移动大量的元素把数据删除或者增加。 链表里的数据是以结点方式来表示的,每一个结点的组成是…

一、链表之单向链表

前面我们使用顺序储存结构实现的顺序表,虽然查询的时候很快,但在进行元素的增加或者删除的时候:比较麻烦,需要你去移动大量的元素把数据删除或者增加。

链表里的数据是以结点方式来表示的,每一个结点的组成是由:数据+指针来组成的。

一个结点的结构是这样的:

单向链表 :

  • 单链表是一种链式储存结构,在物理储存单元不连续,非顺序
  • 由多个结点组成的,每一个结点都是有一个数据域+指针域组成,数据域是用来存储数据元素的,指针用来指向后面的节点。
  • 链表分成带头结点的链表跟不带头结点的链表。
  • 单链表的头节点里不储存数据,它的指针指向真正存储有数据的第一个链表节点。

带头结点的单链表:

 该链表储存地址:

单链表的具体实现,首先需要定义一个类表示每个结点的信息(假设每个结点都是课程的信息):

class CourseNode{public int id;public String courseName;public CourseNode next;public CourseNode(int id, String courseName) {this.id = id;this.courseName = courseName;}@Overridepublic String toString() {return "CourseNode{" +"id=" + id +", courseName='" + courseName + '\'' +", next=" + next +'}';}
}

 然后定义单链表类:

class CourseLinke{//初始化头节点public CourseNode head = new CourseNode(0,"");//链表有效元素个数private int length=0;
}

添加课程的方法:

public void addCourse(CourseNode node){//辅助的指针CourseNode cur = head;//遍历链表,找到最后一个节点while (true){if(cur.next==null){break;}cur=cur.next;}cur.next=node;length++;}

遍历课程的方法:

public void showCourse(){//定义辅助的指针CourseNode cur = head;if(cur.next==null){System.out.println("链表为空,不能输出");return;}while (true){if(cur.next==null){System.out.println("课程输出完成");return;}System.out.println(cur.next);cur=cur.next;}}

 删除课程的方法:

public void delCourse(int id){//定义辅助的指针CourseNode cur = head;if(cur.next == null){return;}//记录是否找到课程boolean flag = false;while (cur.next!=null){if(cur.next.id==id){flag=true;break;}//一直遍历cur=cur.next;}if(flag){//删除节点cur.next=cur.next.next;length--;}else {System.out.printf("要删除的节点%d没有找到",id);}}

修改课程的方法:

public void update(CourseNode node){CourseNode cur = head;boolean flag = false;while (cur.next!=null){if(cur.next.id==node.id){flag=true;break;}cur = cur.next;}if(flag){cur.next.id=node.id;cur.next.courseName=node.courseName;}else {System.out.println("没有找到要修改的课程");}}

接下来我们要实现查找倒数第K个课程,首先我们要先得到链表的长度:

public int getLength(){return length;}

查找倒数第K个课程:

//1、求解链表的长度   2、遍历到链表长度-K+1public CourseNode getLastCourse(int k){CourseNode cur = head;if(cur.next==null){System.out.println("链表为空");return null;}int length = getLength();if(k==0||k>length){throw new IllegalArgumentException("参数不合法");}for (int i=0;i<length-k+1;i++){cur=cur.next;}return cur;}

二、链表之双向链表

双向链表拥有两个指针域,一个指向后继的节点,另一个指向前驱结点。

链表的头结点的数据域是不存储数据的,所以,头结点的前驱指针域为null,它的后继指针域指的是第一个真正有数据存储的结点。

 

http://www.dtcms.com/wzjs/820829.html

相关文章:

  • 2008r2做网站python可以做网站
  • 地接做的网站长沙市网站建设公司
  • 常州城投建设招标网站网站加搜索框
  • 做网站有什么工具seo关键词优化经验技巧
  • 扬中网站推广wordpress汽车模板下载
  • 仙桃哪里做网站网站建设工期及预算
  • 延安网站建设费用在线服装设计网站
  • seo发帖网站青岛网站建设企业
  • 亚马逊服务器做影视网站百度搜索入口官网
  • 微信的微网站海南省住房公积金管理局招聘
  • 网站建设哪里招标网站利用微信拉取用户做登录页
  • 安阳网站如何做优化产品开发流程6个步骤
  • 布吉网站建设哪家效益快网站备案主体授权书
  • 黄石网站建设费用收录情况有几种
  • 企业网站推广工具邢台人才招聘网
  • 青岛城市建设档案馆网站临沂网站建设举措
  • 班级响应式网站html格式网站开发系统简介
  • 百度文库 旅游网站建设方案书旅游型网站开发
  • wordpress国内速度优化网站seo在线诊断分析
  • 油漆涂料网站建设织梦网站做站群
  • 建设个人网站的好处网站开发开题报告
  • php服装网站模板网站网络推广企业
  • 广州市天河区网站设计公司免费婚恋网站设计
  • 三层架构做网站还是系统四川建设集团有限公司网站
  • 太仓专业网站建设单产品网站建设
  • 网站建设找好景科技html5做图书馆网站
  • 淮南家居网站建设怎么样如何使用记事本做网站
  • 新wordpress仿站网站制作尺寸
  • 云盘建设网站网络营销推广的总结
  • 高密做网站的价位企业网站备案案例