数据结构与算法笔记之栈与队列(二)

这篇博客里面有动态演示图,挺适合加深对数据结构模型理解的https://blog.csdn.net/Carty090616/article/details/90287638
1.栈
栈是限制插入和删除只能在一个位置上进行的表,该位置是表的末端,叫作栈顶,对栈的基本操作有push(进栈)和pop(出栈),前者相当于插入,后者相当于删除最后一个元素。特点是先进后出,底层可以采用数组或链表的方式实现。
在这里插入图片描述
(1)采用数组实现
package demo2;

public class MyStack {

//栈的底层我们使用数组来存储数据
int[] elements;

public MyStack() {
	elements = new int[0];
}

//压入元素
public void push(int element) {
	// 创建一个新的数组
	int[] newArr = new int[elements.length + 1];
	// 把原数组中的元素复制到新数组中
	for (int i = 0; i < elements.length; i++) {
		newArr[i] = elements[i];
	}
	// 把添加的元素放入新数组中
	newArr[elements.length] = element;
	// 使用新数组替换旧数组
	elements = newArr;
}

//取出栈顶元素
public int pop() {
	//栈中没有元素
	if(elements.length==0) {
		throw new RuntimeException("stack is empty");
	}
	//取出数组的最后一个元素
	int element = elements[elements.length-1];
	//创建一个新的数组
	int[] newArr = new int[elements.length-1];
	//原数组中除了最后一个元素的其它元素都放入新的数组中
	for(int i=0;i<elements.length-1;i++) {
		newArr[i]=elements[i];
	}
	//替换数组
	elements=newArr;
	//返回栈顶元素
	return element;
}

//查看栈顶元素
public int peek() {
	//栈中没有元素
	if(elements.length==0) {
		throw new RuntimeException("stack is empty");
	}
	return elements[elements.length-1];
}

//判断栈是否为空
public boolean isEmpty() {
	return elements.length==0;
}

}

(2)采用单向链表实现
https://blog.csdn.net/weixin_38719347/article/details/81940234
public class StackSingleLink {
4 private SingleLinkedList link;
5
6 public StackSingleLink(){
7 link = new SingleLinkedList();
8 }
9
10 //添加元素
11 public void push(Object obj){
12 link.addHead(obj);
13 }
14
15 //移除栈顶元素
16 public Object pop(){
17 Object obj = link.deleteHead();
18 return obj;
19 }
20
21 //判断是否为空
22 public boolean isEmpty(){
23 return link.isEmpty();
24 }
25
26 //打印栈内元素信息
27 public void display(){
28 link.display();
29 }
30
31 }

2队列
队列是一种特殊的线性表,特殊之处在于它只允许在表的前端(front)进行删除操作,而在表的后端(rear)进行插入操作,和栈一样,队列是一种操作受限制的线性表。进行插入操作的端称为队尾,进行删除操作的端称为队头。队列可以使用链表或者数组来实现,原文采用链表,在这使用数组来实现。
链接:https://www.jianshu.com/p/230e6fde9c75
在这里插入图片描述

package demo2;

import javax.swing.text.DefaultStyledDocument.ElementSpec;

public class MyQueue {

int[] elements;

public MyQueue() {
	elements=new int[0];
}

//入队
public void add(int element) {
	// 创建一个新的数组
	int[] newArr = new int[elements.length + 1];
	// 把原数组中的元素复制到新数组中
	for (int i = 0; i < elements.length; i++) {
		newArr[i] = elements[i];
	}
	// 把添加的元素放入新数组中
	newArr[elements.length] = element;
	// 使用新数组替换旧数组
	elements = newArr;
}

//出队
public int poll() {
	//把数组中的第0个元素取出来
	int element = elements[0];
	//创建一个新的数组
	int[] newArr = new int[elements.length-1];
	//复制原数组中的元素到新数组中
	for(int i=0;i<newArr.length;i++) {
		newArr[i]=elements[i+1];
	}
	//替换数组
	elements=newArr;
	return element;
}

//判断队列是否为空
public boolean isEmpty() {
	return elements.length==0;
}

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值