zoukankan      html  css  js  c++  java
  • 数组实现栈和队列


    /**
    * 数组实现栈和队列
    */
    public class ArrayToQueueAndStack {

    public static class MyStack<T> {

    public Object[] arr;

    public int size;

    public int limit;

    public MyStack(int limit) {
    this.arr = new Object[limit];
    this.limit = limit;
    }

    public void push(T value) {
    if (size == limit) {
    System.out.println("the stack is full");
    return;
    }
    arr[size++] = value;
    }

    public T pop() {
    if (isEmpty()) {
    System.out.println("the stack is empty");
    return null;
    }
    return (T) arr[--size];
    }

    public boolean isEmpty() {
    return size == 0;
    }

    }

    public static class MyQueue<T> {

    public Object[] arr;

    public int pushIndex;

    public int pollIndex;

    public int size;

    public int limit;

    public MyQueue(int limit) {
    this.arr = new Object[limit];
    this.limit = limit;
    }

    public void push(T value) {
    if (size == limit) {
    System.out.println("the queue is full");
    return;
    }
    arr[pushIndex] = value;
    size++;
    pushIndex = nextIndex(pushIndex);
    }

    public T poll() {
    if (isEmpty()) {
    System.out.println("the queue is empty");
    return null;
    }
    T value = (T) arr[pollIndex];
    size--;
    pollIndex = nextIndex(pollIndex);
    return value;
    }

    public boolean isEmpty() {
    return size == 0;
    }

    private int nextIndex(int pushIndex) {
    return ++pushIndex % limit;
    }

    }

    }

    /* 如有错误,欢迎批评指正 */
  • 相关阅读:
    Linux后台进程管理的一些命令小结
    Linux 技巧:让进程在后台可靠运行的几种方法
    python对图片进行分割
    pytorch实现优化optimize
    pytorch实现批训练
    pytorch实现网络的保存和提取
    pytorch实现分类
    pytorch实现回归任务
    递推之数字三角形
    深搜——蓝桥杯之迷宫
  • 原文地址:https://www.cnblogs.com/laydown/p/12798221.html
Copyright © 2011-2022 走看看