数据结构(data structure)(1)链表和线性表

2024-04-21 05:12

本文主要是介绍数据结构(data structure)(1)链表和线性表,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

 类和对象

对象将数据和操作打包在一起,类描述了这一切
用构造器创建(实例化)对象
类和类之间的关系
-关联(组合,聚集)
-泛化private class Student{protected String name;protected int age;protected int ability;public Student(String name,int age){this.name=name;this.age=age;}
4public  void study(){ability++;}public String toString(){return "Student{"+"name="+name+'\''+",age"+age+",ability="+ability+'}';}public boolean equals(Object o){if(this==o)return true;if(o==null||getClass()!=o.getClass())return false;Student student =(Student)o;return name.equals(student.name);}public static void main(String[] args){Student stu1=new Student();Student stu2=new Student();System.out.println(stu1.toString());System.out.println(stu1.equal(stu2));}
}

关于继承

祖先类Object
方法重写
toString方法
equals方法public class CleverStudent extends Student{public CleverStudent(String name,int age){super(name,age);}public void study(){super.study();super.study();}public void study(int s){ability+=s;}
}Comparable接口,比较大小
Comparator接口,比较器
Cloneable接口,克隆
seriazable接口,可序列化,io接入网路需要

数据结构基本概念

数据(data)
数据元素(data element)
数据对象(data object)数据是一种泛指数据对象
数据元素
数据项(数据对象)student
{(name(数据项),age)   (数据元素)
}

数据结构(data structure)

辑结构
集合:元素罗列在一起
线性结构:元素前后相继(一一对应)
树形结构:(元素存在一对多的关系)
图结构或网状结构:元素之间存在多对多的结构存储结构
-顺序存储:地址连续,用数组
-链式存储:地址不连续,用指针(引用,面向对象)Create建立
Destroy消除
Delete删除
Insert插入
Access访问
Modify修改
Sort排序
Search查找
增删改查排历

 列表:顺序表和链表

定义列表接口
用数组实现列表-MyArrayList
实现列表
Java List API

 顺序表

public interface MyList{//新增一个元素void add(Object element);//删除相同元素void delete(Object element)//根据索引删除元素void delete(int index);//将指定索引位置的·元素替换成新元素void update(int index,Object newElement);//当前列表中是否含有target元素boolean contains(Object target);//返回指定索引处元素Object indexOf(int index);}public class MyArrayList implements MyList{private int size=0//元素个数private int capacity;//容量public MyArrayList(int capacity){this.capacity=capacity;elements=new Object[capacity];
}//新增一个元素void add(Object element){if(size==capacity)//扩容{capacity*=2;//增加一倍的容量Object[] newArr=new Object[capacity];//把旧的柜子扔掉newArr[i]=elements[i];}elements[size++]=element;}//删除相同元素void delete(Object element){int index=indexOf(element);if(index>=0){delete(index);}}//根据索引删除元素void delete(int index){for(int i=index;i<size;i++){elements[i]=elements[i+1];}size--;}//将指定索引位置的·元素替换成新元素void update(int index,Object newElement){elemenyts[index]=newElement;}//当前列表中是否含有target元素boolean contains(Object target){}//返回指定索引处元素Object at(int index){return elements[index];}//查找element的索引,如果没有返回-1Object indexOf(Object element){for(int i=0;i<size;i++){if(elements[i].equals(element))return i;}return -1;}public String toString(){StringgBuilder sb=new StringBuilder("[");for(int i=0;i<size;i++){sb.append(elements[i]+(i==size-1?"":","));}sb.appen("]");return sb.toString();}}publi class MyArraylistTest{public  void add() throw Exception{MyArrayList list=new MyArrayList();list.add("nike");List.add("addidiaos");List.add("nb");}}

单链表

head头节点,Node[data,point]->[data,point]->[]->[]public class ListNode{private Object data;private ListNode next;public ListNode(data){this.data=data;}}public class SingleLinkedList implements Mylist{private ListNode first;//头节点private ListNode last;//尾节点public void add(Object element){if(first==null){//如果头节点为空,将新增节点给头节点first=new ListNode(element);last=head;//此时尾节点等于头节点}else{last.next=new ListNode(element);//新增节点last=last.Next;//尾节点更新到新增的一个节点位置上}size++;
}//新增一个元素//删除相同元素public  void delete(Object element){ListNode p=first;ListNode pre=null;//p前面的位置while(p!=null){if(p.data.equals(element)){if(p==first){//如果删除头指针元素,让头指针往后挪一位就可以了first=first.next;}pre.next=p.next;break;}pre=p;//等于p的位置,p再移动一位,pre就在p的前面了p=p.next;}size--;}//根据索引删除元素public void delete(int index){if(index<0||index>size){return;//啥也不干}int i=0;ListNode p=first;ListNode pre=null;while(p!=null){if(i==index){if(p==first){first=first.next;}else{pre.next=p.next;}break;}pre=p;p=p.next;i++;}、size--;}//将指定索引位置的·元素替换成新元素public void update(int index,Object newElement){if(index<0||index>=size){return;}int i=0;ListNode p=first;while(p!=null){if(i==index){p.data=newElement;break;}p=p.next;i++;}}//当前列表中是否含有target元素public  boolean contains(Object target){ListNode p=first;while(p!=null){if(p.data.equals(target)){return true;}p=p.next;}return false;}//返回指定索引处元素public Object at(int index){if(index<0||index>size){return;//啥也不干}int i=0;//指针指向的节点的索引ListNode p=first;while(p!=null){if(i==index){return p.data;break;}p=p.next;i++;}}public int indexOf(Object element){int i=0;//指针指向的节点的索引ListNode p=first;while(p!=null){if(p.data.equals(element)){return i;break;}p=p.next;i++;}return -1;}public String toString(){StringBuilder sb=new StringBuilder();ListNode p=first;while(p.next!=null){sb.append(p.data).append(",");p=p.next;}sb.append("]");return sb.toString();}}
//增和删链表更快

双向链表

first和last是亚元所代表的值为null<-    <-    <-
null->head->Node->Node->tail->null
a0     a1    a2    a3
双向链表结构public class ListNode{Object data;ListNode pre;ListNode next;public listNode(Object data){this.data=data;}
}public class DoubleLinkedList implements Mylist{private ListNode first=new ListNode(null);//头节点private ListNode last=new ListNode(null);//尾节点private size=0;public DoubleLinkList(){first.next=last;last.pre=first;}public void add(Object element){ListNode newNode=new ListNode(element);last.pre.next=newNode;newNode.next=last;newNode.pre=last.pre;last.pre=newNode;size++;}//新增一个元素//删除相同元素public  void delete(Object element){ListNode p=first.next;//first为nullwhile(p!=last){if(p.data.equals(element)){p.pre.next=p.next;p.next.pre=p.pre;p.next=null;p.pre=null;size--;break;}p=p.next;}}//根据索引删除元素public void delete(int index){if(index<0||index>size){return;//啥也不干}int i=0;ListNode p=first.next;//从first的下一个元素开始while(p!=last){if(i==index){p.pre.next=p.next;p.next.pre=p.pre;p.next=null;p.pre=null;size--;break;//注意这里}p=p.next;i++;}、}//将指定索引位置的·元素替换成新元素public void update(int index,Object newElement){if(index<0||index>=size){return;}int i=0;ListNode p=first.next;while(p!=last){if(i==index){p.data=newElement;break;}p=p.next;i++;}}//当前列表中是否含有target元素public  boolean contains(Object target){ListNode p=first.next;while(p!=last){if(p.data.equals(target)){return true;}p=p.next;}return false;}//返回指定索引处元素public Object at(int index){if(index<0||index>size){return;//啥也不干}int i=0;//指针指向的节点的索引ListNode p=first.next;while(p!=last){if(i==index){return p.data;break;}p=p.next;i++;}return null;}public int indexOf(Object element){int i=0;//指针指向的节点的索引ListNode p=first.next;while(p!=last){if(p.data.equals(element)){return i;break;}p=p.next;i++;}return -1;}public String toString(){StringBuilder sb=new StringBuilder();ListNode p=first.next;while(p!=last){sb.append(p.data);if(p.next!=last)sb.append(",");p=p.next;}sb.append("]");return sb.toString();}}

迭代器

public interface Iterator<E>{boolean hasNext();Object next();}public interface MyList extends Iterator{//新增一个元素void add(Object element);//删除相同元素void delete(Object element)//根据索引删除元素void delete(int index);//将指定索引位置的·元素替换成新元素void update(int index,Object newElement);//当前列表中是否含有target元素boolean contains(Object target);//返回指定索引处元素Object indexOf(int index);boolean hasNext();Object next();}public class DoubleLinkedList implements Mylist{private ListNode first=new ListNode(null);//头节点private ListNode last=new ListNode(null);//尾节点private size=0;public DoubleLinkList(){first.next=last;last.pre=first;}public void add(Object element){ListNode newNode=new ListNode(element);last.pre.next=newNode;newNode.next=last;newNode.pre=last.pre;last.pre=newNode;size++;}//新增一个元素//删除相同元素public  void delete(Object element){ListNode p=first.next;//first为nullwhile(p!=last){if(p.data.equals(element)){p.pre.next=p.next;p.next.pre=p.pre;p.next=null;p.pre=null;size--;break;}p=p.next;}}//根据索引删除元素public void delete(int index){if(index<0||index>size){return;//啥也不干}int i=0;ListNode p=first.next;//从first的下一个元素开始while(p!=last){if(i==index){p.pre.next=p.next;p.next.pre=p.pre;p.next=null;p.pre=null;size--;break;//注意这里}p=p.next;i++;}、}//将指定索引位置的·元素替换成新元素public void update(int index,Object newElement){if(index<0||index>=size){return;}int i=0;ListNode p=first.next;while(p!=last){if(i==index){p.data=newElement;break;}p=p.next;i++;}}//当前列表中是否含有target元素public  boolean contains(Object target){ListNode p=first.next;while(p!=last){if(p.data.equals(target)){return true;}p=p.next;}return false;}//返回指定索引处元素public Object at(int index){if(index<0||index>size){return;//啥也不干}int i=0;//指针指向的节点的索引ListNode p=first.next;while(p!=last){if(i==index){return p.data;break;}p=p.next;i++;}return null;}public int indexOf(Object element){int i=0;//指针指向的节点的索引ListNode p=first.next;while(p!=last){if(p.data.equals(element)){return i;break;}p=p.next;i++;}return -1;}public String toString(){StringBuilder sb=new StringBuilder();ListNode p=first.next;while(p!=last){sb.append(p.data);if(p.next!=last)sb.append(",");p=p.next;}sb.append("]");return sb.toString();}private ListNode now=first;public boolean hasNext(){return now.next!=last;;}public Object next(){ListNode next=now.next;now=now.next;return next.data;}}public iter(){while(list.hashNext()){String next=list.next();System.out.println(next);}
}//<T>泛型可以替换掉object

java List API

 

sort{set,List,Tree}collection|               |         |List           Set        Queue|     |        |
Stack ArrayList LinkedListList<String> list=new ArrayList<>();
list=new LinkedList<>();
list.add("asda");
list.remove("");Collection.sort(list);List<Student>list1=new ArrayList<>();
list1.add(new Student("zhangsan",10));
list1.add(new Student("isli",20));
Collection.sort(list1,(o1,o2)->{//camparetor排序器return o1.get()-o2.get();});for(int i=0;i<list1.size();i++){System.out.println(list1.get(i));
}//不能删东西,需要确保边界for(Student stu:list1){System.out.println(stu);
}Iterator<Student> iterator=new list1.Iterator();
//Iterator可以
while(iterator.hasNext()){System.out,println(iterator.next());
}

这篇关于数据结构(data structure)(1)链表和线性表的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/922225

相关文章

使用C++实现链表元素的反转

《使用C++实现链表元素的反转》反转链表是链表操作中一个经典的问题,也是面试中常见的考题,本文将从思路到实现一步步地讲解如何实现链表的反转,帮助初学者理解这一操作,我们将使用C++代码演示具体实现,同... 目录问题定义思路分析代码实现带头节点的链表代码讲解其他实现方式时间和空间复杂度分析总结问题定义给定

Go语言中三种容器类型的数据结构详解

《Go语言中三种容器类型的数据结构详解》在Go语言中,有三种主要的容器类型用于存储和操作集合数据:本文主要介绍三者的使用与区别,感兴趣的小伙伴可以跟随小编一起学习一下... 目录基本概念1. 数组(Array)2. 切片(Slice)3. 映射(Map)对比总结注意事项基本概念在 Go 语言中,有三种主要

【数据结构】——原来排序算法搞懂这些就行,轻松拿捏

前言:快速排序的实现最重要的是找基准值,下面让我们来了解如何实现找基准值 基准值的注释:在快排的过程中,每一次我们要取一个元素作为枢纽值,以这个数字来将序列划分为两部分。 在此我们采用三数取中法,也就是取左端、中间、右端三个数,然后进行排序,将中间数作为枢纽值。 快速排序实现主框架: //快速排序 void QuickSort(int* arr, int left, int rig

csu1329(双向链表)

题意:给n个盒子,编号为1到n,四个操作:1、将x盒子移到y的左边;2、将x盒子移到y的右边;3、交换x和y盒子的位置;4、将所有的盒子反过来放。 思路分析:用双向链表解决。每个操作的时间复杂度为O(1),用数组来模拟链表,下面的代码是参考刘老师的标程写的。 代码如下: #include<iostream>#include<algorithm>#include<stdio.h>#

6.1.数据结构-c/c++堆详解下篇(堆排序,TopK问题)

上篇:6.1.数据结构-c/c++模拟实现堆上篇(向下,上调整算法,建堆,增删数据)-CSDN博客 本章重点 1.使用堆来完成堆排序 2.使用堆解决TopK问题 目录 一.堆排序 1.1 思路 1.2 代码 1.3 简单测试 二.TopK问题 2.1 思路(求最小): 2.2 C语言代码(手写堆) 2.3 C++代码(使用优先级队列 priority_queue)

深入手撕链表

链表 分类概念单链表增尾插头插插入 删尾删头删删除 查完整实现带头不带头 双向链表初始化增尾插头插插入 删查完整代码 数组 分类 #mermaid-svg-qKD178fTiiaYeKjl {font-family:"trebuchet ms",verdana,arial,sans-serif;font-size:16px;fill:#333;}#mermaid-svg-

论文翻译:arxiv-2024 Benchmark Data Contamination of Large Language Models: A Survey

Benchmark Data Contamination of Large Language Models: A Survey https://arxiv.org/abs/2406.04244 大规模语言模型的基准数据污染:一项综述 文章目录 大规模语言模型的基准数据污染:一项综述摘要1 引言 摘要 大规模语言模型(LLMs),如GPT-4、Claude-3和Gemini的快

建立升序链表

题目1181:遍历链表 时间限制:1 秒 内存限制:32 兆 特殊判题:否 提交:2744 解决:1186 题目描述: 建立一个升序链表并遍历输出。 输入: 输入的每个案例中第一行包括1个整数:n(1<=n<=1000),接下来的一行包括n个整数。 输出: 可能有多组测试数据,对于每组数据, 将n个整数建立升序链表,之后遍历链表并输出。 样例输

《数据结构(C语言版)第二版》第八章-排序(8.3-交换排序、8.4-选择排序)

8.3 交换排序 8.3.1 冒泡排序 【算法特点】 (1) 稳定排序。 (2) 可用于链式存储结构。 (3) 移动记录次数较多,算法平均时间性能比直接插入排序差。当初始记录无序,n较大时, 此算法不宜采用。 #include <stdio.h>#include <stdlib.h>#define MAXSIZE 26typedef int KeyType;typedef char In

【每日一题】LeetCode 2181.合并零之间的节点(链表、模拟)

【每日一题】LeetCode 2181.合并零之间的节点(链表、模拟) 题目描述 给定一个链表,链表中的每个节点代表一个整数。链表中的整数由 0 分隔开,表示不同的区间。链表的开始和结束节点的值都为 0。任务是将每两个相邻的 0 之间的所有节点合并成一个节点,新节点的值为原区间内所有节点值的和。合并后,需要移除所有的 0,并返回修改后的链表头节点。 思路分析 初始化:创建一个虚拟头节点