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

引入

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

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

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

相关推荐
Code成立几秒前
《Java核心技术I》Swing的网格包布局
java·开发语言·swing
中草药z6 分钟前
【Spring】深入解析 Spring 原理:Bean 的多方面剖析(源码阅读)
java·数据库·spring boot·spring·bean·源码阅读
信徒_14 分钟前
常用设计模式
java·单例模式·设计模式
不惑_15 分钟前
List 集合安全操作指南:避免 ConcurrentModificationException 与提升性能
数据结构·安全·list
神仙别闹19 分钟前
基于C#实现的(WinForm)模拟操作系统文件管理系统
java·git·ffmpeg
小爬虫程序猿20 分钟前
利用Java爬虫速卖通按关键字搜索AliExpress商品
java·开发语言·爬虫
组合缺一25 分钟前
Solon v3.0.5 发布!(Spring 可以退休了吗?)
java·后端·spring·solon
程序猿零零漆28 分钟前
SpringCloud 系列教程:微服务的未来(二)Mybatis-Plus的条件构造器、自定义SQL、Service接口基本用法
java·spring cloud·mybatis-plus
猿来入此小猿30 分钟前
基于SpringBoot在线音乐系统平台功能实现十二
java·spring boot·后端·毕业设计·音乐系统·音乐平台·毕业源码
愤怒的代码43 分钟前
Spring Boot对访问密钥加解密——HMAC-SHA256
java·spring boot·后端