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

引入

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

数据结构是计算机中存储、组织和管理数据的方式,它决定了数据如何被存储以及如何进行高效访问和修改。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;
      }
}

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

相关推荐
Chengbei1111 分钟前
一站式源码安全检测工具、云安全 / APP / 小程序源码敏感信息递归多层目录扫描AK、JWT、手机号、身份证等敏感信息
java·开发语言·安全·web安全·网络安全·系统安全·安全架构
llz_11216 分钟前
web-第一次课后作业
java·开发语言·idea
kkeeper~21 分钟前
0基础C语言积跬步之数据在内存中的存储
c语言·数据结构·算法
秋931 分钟前
Java项目运行5天左右自动宕机:系统性定位与解决方案
java·开发语言·python
小江的记录本37 分钟前
【JVM虚拟机】垃圾回收GC:垃圾收集器:CMS:核心原理、回收流程、优缺点、废弃原因(附《思维导图》+《面试高频考点清单》)
java·jvm·后端·python·spring·面试·maven
2401_868534781 小时前
论企业网络设计
数据结构
DIY源码阁1 小时前
JavaSwing学生成绩管理系统 - MySQL版
java·数据库·mysql·eclipse
2401_876964132 小时前
【湖北专升本】2026湖北专升本真题PDF+备考资料汇总
数据结构·人工智能·经验分享·深度学习·算法·计算机视觉
basketball6162 小时前
C++ NULL 和 nullptr 区别 以及 nullptr 的核心实现
java·开发语言·c++
JAVA面经实录9173 小时前
MyBatis面试题库
java·mybatis