数据结构--数组实现栈和队列

引入

什么是 数据结构?(・∀・(・∀・(・∀・*)

数据结构是计算机中存储、组织和管理数据的方式,它决定了数据如何被存储以及如何进行高效访问和修改。o(* ̄▽ ̄*)ブ

什么是算法?

算法本质上就是对数据进行一系列增删改查。

什么是栈?

栈就是一种遵循**"后进先出"**规则的一种数据结构。

什么是队列?

队列就是遵循**"先进先出,后进后出"**规则的一种数据结构。

有了上述概念后,就可以编写以下入栈出栈,入队列出队列的函数了。

1.入栈和出栈

java 复制代码
public class Stack{
    private int[] arr;
    private int i=-1;
    
     public Stack(int size){
         arr[]=new int[size];            
     }
     public void put(int value){
         //判断栈满(否则会越界错误)
         if(i==arr.length-1){
             System.out.println("栈已经满了!");
             return;       
         }     
         //没满就填入数据
          i++;
         arr[i]=value; 
     }
     public int get(){
         //同样,判断是否已空
         if(i==-1){
             System.out.println("栈已经空了!");
             return -100000;                  
         }     
         //取数据
         value=arr[i];
         i--;
         return value;
     }

}

2.入队列和出队列

java 复制代码
public class Queue{
    private int[] arr;
    private int l=0;
    private int r=0;
    
    
     public Queue(int size){
         arr[]=new int[size];            
     }
     
      public void put(int value){
           //判断是否满
           if(r-l=arr.length){
               System.out.println("已经满了!");
               return;              
           }    
           //实现循环队列的关键
           arr[l%arr.length]=value;
           l++;
      }
       public int get(int value){
           //判断是否满
           if(r==l){
               System.out.println("已经空了!");
               return -10000;              
           }    
           //实现循环队列的关键
           value=arr[c%arr.length];
           c++;
           return value;
      }
}

以上就是两个用数组实现入栈出栈,入队列和出队列的类。

相关推荐
jakeswang20 分钟前
spring循环依赖以及MyBatis-Plus的继承特性导致循环依赖自动解决失效
java·spring·mybatis
疯一样的码农23 分钟前
使用命令行创建一个简单的 Maven Web 应用程序
java·maven
m0_5474866625 分钟前
数据结构试选择题及答案1
数据结构
知识鱼丸28 分钟前
【数据结构】一图介绍python数据结构
数据结构·python
sweetheart7-731 分钟前
LeetCode155. 最小栈(2024冬季每日一题 12)
算法··模拟栈·最小元素
SlothLu39 分钟前
Debezium-BinaryLogClient
java·mysql·kafka·binlog·多线程·debezium·数据迁移
MZWeiei2 小时前
实现List接口的三类-ArrayList -Vector -LinkedList
java
怀旧6662 小时前
Java List 集合
java·数据结构·后端·list·个人开发
听我对云说2 小时前
Java语言程序设计 选填题知识点总结
java·开发语言
苹果酱05672 小时前
浅谈vue3 和 vue2的区别
java·spring boot·毕业设计·layui·课程设计