ADT基础(一)—— List,Stack,and Queue
ADT基础(一)—— List,Stack,and Queue
1 List 表示
数组:易于search,难于insert和remove
链表:难于search,易于insert和remove
//Node类,LinkedList类
public class LinkedList{
Node head = null;
class Node{ //element和next
object element;
Node next;
Node(object e){
this.element = e;
}
}
//输出链表并获取长度
int getLength(){
int length = 0;
Node tmp = head;
while(tmp != null){
length++;
System.out.println(tmp.data);
tmp = tmp.next;
}
return length;
}
//查询element为e的第一个位置
int getIndex(object e){
int index = -1;
Node tmp = head;
while(tmp!=null){
index++:
if(tmp.element == e){
return index;
}
tmp = tmp.next;
}
return -1;
}
//获取指定位置的element
object getObject(int index){
if(index<0||index >= getLength()) //print fault;
Node tmp = head;
if(head==null) //print fault;
for(int i=0;i<index;i++){
tmp = tmp.next;
}
return tmp.element;
}
//头插法
void addHead(object e){
Node newNode = new Node(e);
newNode.next = head;
head = newNode;
}
//尾插法
void addTail(object e){
Node newNode = new Node(e);
if(head == null) head = newNode;
else{
Node tmp = head;
while(tmp.next != null){
tmp = tmp.next;
}
tmp.next = newNode;
}
}
//随机节点插入法
void insert(int index,object e){
int size = getLength();
if(index>=size||index<0) //print fault;
if(index==0) addHead(e);
else if(index == size-1) addTail(e);
else{
Node pre = head;
Node cur = head.next;
for(int i=0;i<index-1;i++){
pre = pre.next;
cur = cur.next;
}
//pre保存索引上一个节点,cur保存索引值当前节点
Node newNode = new Node(e);
pre.next = newNode;
newNode.next = cur;
}
}
//删除头节点
void deleteHead(){
if(head == null) return;
head = head.next;
}
//删除尾节点
void deleteTail(){
if(head==null) return;
Node btmp = head;
Node tmp = btmp.next;
if(tmp == null){
head = null;
return;
}
while(tmp.next != null){
btmp = tmp;
tmp = tmp.next;
}
btmp.next = null;
}
//随机删除节点
void remove(int index){
int size = getLength();
if(index<0||index>=size) //print fault;
if(index == 0) deleteHead();
else if(index == size-1) deleteTail();
else{
Node pre = head;
for(int i=0;i<index-1;i++){
pre = pre.next;
}
pre.next = pre.next.next;
}
}
}
//由单链表的增加删除可以看出,链表想要对指定索引进行操作(增加,删除),则必须获取该索引的前一个元素。记住这句话,对链表算法题很有用。
2 Stack表示
- 后入先出
//栈的链表实现,栈顶在topOfStack,即head处;
//push和pop都在head处
public class StackLi
{
public StackLi( ){ topOfStack = null; }
public boolean isFull( ){ return false; }
public boolean isEmpty( ){ return topOfStack = = null; }
public void makeEmpty( ){ topOfStack = null; }
public void push( object x){
topOfStack = new ListNode(x,topOfStack);
}
public object top(){
if(topOfStack == null) return null;
return topOfStack.element;
}
public void pop() throws Underflow{
if(topOfStack == null) throw new Underflow();
topOfStack = topOfStack.next;
}
public object topAndPop( ){
if(topOfStack == null) return null;
object res = topOfStack.element;
topOfStack = topOfStack.next;
return res;
}
private ListNode topOfStack;
}
//栈的数组实现,栈顶在topOfStack,即在数组n-1位上(假设压入n个元素);
//push和pop依次向后或向前
public class stackAr{
public StackAr( ){
this(DEFAULT_CAPACITY);
}
public StackAr(int capacity){
theArray = new object[capacity];
topOfStack = -1;
}
public boolean isEmpty( ){ return topOfStack == -1; }
public boolean isFull( ){ return topOfStack == theArray.length –1; }
public void makeEmpty( ){ topOfStack = -1; }
public void push( object x ) throws overflow{
if(topOfStack == theArray.length - 1) throw new Overflow();
topOfStack++;
theArray[topOfstack] = x;
}
public object top( ){
if(topOfStack==-1) return null;
return theArray[topOfStack];
}
public void pop( ) throws Underflow{
if(topOfStack == -1) throw new Undewflow();
theArray[topOfStack] == null;
topOfStack--;
}
public object topAndPop( ){
if(topOfStack==-1) return null;
object res = theArray[topOfStack];
theArray[topOfStack] == null;
topOfStack--;
return res;
}
private object [ ] theArray;
private int topOfStack;
static final int DEFAULT_CAPACITY = 10;
}
3 Queue表示
- 插入与删除在不同端,先入先出
//队列的数组实现,在front位删除,在back位插入 front到back由0到n-1
public class QueueAr
{
public QueueAr(){
this(DEFAULT_CAPACITY);
}
public QueueAr( int capacity){
theArray = new Object[capacity];
currentSize = 0;
front = 0;
back = -1;
}
public boolean isEmpty( ){ return currentsize == 0; }
public boolean isfull( ){ return currentSize == theArray.length; }
public Object getfront( )
public void enqueue( Object x ) throw Overflow{
if(currentSize == theArray.length) throw new Overflow();
back++;
if(back == theArray.length) back = 0; //队列满则新元素回到0位插入
theArray[back] = x;
currentSize++;
}
private Object dequeue( ){
if(currentSize == 0) return null;
curretSize--;
object res = theArray[front];
theArray[front] = null;
front++;
if(front == theArray.length) front = 0; //队列删到尾则回到0删除
return res;
}
private Object [ ] theArray;
private int currentSize;
private int front; //删除
private int back; //插入
static final int DEFAULT_CAPACITY = 10;
}
//队列的链表实现,front在head
public class LinkedQueue
{
public LinkedQueue(){
this.head = null;
this.tail = null;
this.size = 0;
}
public boolean IsEmpty(){return size==0;}
public boolean IsFull(){return false};
public void add(object x){
if(size==0){
head = new Node(x);
tail = head;
size++;
}else{
tail.next = new Node(x);
tail = tail.next;
size++;
}
}
public object delete(){
if(size==0) return null;
object res = head.element;
head = head.next;
if(head == null) tail = null; //head为null,代表已经行进到tail.next,此时为空链表
size--;
return res;
}
private Node head;
private Node tail;
private int size;
};
ADT基础(一)—— List,Stack,and Queue的更多相关文章
- page74-泛型可迭代的基础集合数据类型的API-Bag+Queue+Stack
[泛型可迭代的基础集合数据类型的API] 背包:就是一种不支持从中删除元素的集合数据类型——它的目的就是帮助用例收集元素并迭代遍历所有收集到的元素.(用例也可以检查背包是否为空, 或者获取背包中元素的 ...
- bfs和dfs辨析—基础复习(从stack和queue的角度来理解区别,加深理解,不再模糊)
参考: https://www.cnblogs.com/Tovi/articles/6194815.html https://blog.csdn.net/dangzhangjing97/article ...
- Java容器:Stack,Queue,PriorityQueue和BlockingQueue
Stack Queue PriorityQueue BlockingQueue ArrayBlockingQueue LinkedBlockingQueue PriorityBlockingQueue ...
- ADT基础(二)—— Tree,Heap and Graph
ADT基础(二)-- Tree,Heap and Graph 1 Tree(二叉树) 先根遍历 (若二叉树为空,则退出,否则进行下面操作) 访问根节点 先根遍历左子树 先根遍历右子树 退出 访问顺序为 ...
- Java集合的Stack、Queue、Map的遍历
Java集合的Stack.Queue.Map的遍历 在集合操作中,常常离不开对集合的遍历,对集合遍历一般来说一个foreach就搞定了,但是,对于Stack.Queue.Map类型的遍历,还是有一 ...
- [STL]deque和stack、queue
怎么说呢,deque是一种双向开口的连续线性空间,至少逻辑上看上去是这样.然而事实上却没有那么简单,准确来说deque其实是一种分段连续空间,因此其实现以及各种操作比vector复杂的多. 一.deq ...
- python实现之极简stack和queue
用python实现一个极简的stack和queue,那是so easy的事情了,简洁易懂,适合小白~ 直接上代码吧: node: class LinkNode: def __init__( self, ...
- C++ STL stack和queue
C++ STL中独立的序列式容器只有vector,list,deque三种,stack和queue其实就是使用容器适配器对deque进行了封装,使用了新接口. 使用标准库的栈和队列时,先包含相关的头文 ...
- 剑指offer——stack与queue的互相实现
我们知道,stack和queue是C++中常见的container.下面,我们来探究下如何以stack来实现queue,以及如何用queue来实现stack. 首先,先了解下stack与queue的基 ...
随机推荐
- 500行SQL快速实现UCF
写在前面话 UCF通常是User-base Collaborative Filter的简写;大体的算法思路是根据用户行为计算相似群体(邻居),为用户推荐其邻居喜好的内容:感觉是不是很简单.那废话不多说 ...
- 十四自定义构建购物计算组件&表单组件
目录: 1.前言 2.组件介绍 3.js业务逻辑层 4.视图层 5.css属性设置 6.效果呈现 1.前言: 在第九篇文章购物车做好后,还忘记了一个至关重要的计算组件.在鸿蒙的组件中并没有提供这样一个 ...
- [The Preliminary Contest for ICPC Asia Shanghai 2019] B-Light bulbs(差分+思维)
前言 最近有很多算不上事的事,搞得有点心烦,补题难免就很水,没怎么搞,自我检讨一番~~ 说实话网络赛题目的质量还是挺高的,题目都设计的挺好的,很值得学习.这场比赛那会只有我们大二的在做,其他人去参加$ ...
- Codeforces Global Round 7 B. Maximums(逻辑)
题意: 有数组 an,定义 xi 为 a 的前 i - 1 位的最大值(x0 = 0),定义 bi 为 ai - xi,给出数组 bn,还原数组 an. 思路: 因为 x0 = 0,所以 b0 = a ...
- linux命令行创建快捷方式
ln -s 源文件 目标目录 https://blog.csdn.net/ljw_jiawei/article/details/91044595
- [Angular] 删除旧版本,升级安装最新版本
目录 删除旧版本 清除未卸载干净的angular-cli缓存 对于Linux 对于Windows 安装最新版本 查看安装版本 创建新项目 删除旧版本 npm uninstall -g angular- ...
- 网络协议 & 协议体系结构模型
基本知识概述 网络协议是什么? 为进行网络中的数据交换,而建立的规则(约定),就称为网络协议 网络协议的三个组成要素? 语法:数据与控制信息的结构或格式 语义:发出何种控制信息,完成何种动作,作出何种 ...
- C语言经典面试题
[题目]零值比较--BOOL,int,float,指针变量与零值比较的if语句. (首先给个提示:题目中要求的是零值比较,而非与0进行比较,在C++里"零值"的范围可就大了,可以是 ...
- C++ part8
1.volatile关键字 在C++中,对volatile修饰的对象的访问,有编译器优化上的副作用: 不允许被编译器优化,提供特殊地址的稳定访问(只从内存中读取). 有序性,编译器进行优化时,不能把对 ...
- Pycharm缺少环境变量+无法获取libcudnn.so.6
在终端输入: echo LD_LIBRARY_PATH, 并将其内容 添加至Pycharm的 run -> Edit configuration -> Environment variab ...