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

引入

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

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

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

相关推荐
E_ICEBLUE13 分钟前
Excel vs CSV:在系统数据处理中该如何选择?
java·excel·csv·格式转换
wWYy.30 分钟前
详解redis(8):数据结构Hash
数据结构·redis·哈希算法
智者知已应修善业41 分钟前
【输出一个N*N的01矩阵,表示最后的汉字点阵图】2024-10-22
c语言·数据结构·c++·经验分享·笔记·算法·矩阵
郑州光合科技余经理1 小时前
同城020系统架构实战:中台化设计与部署
java·大数据·开发语言·后端·系统架构·uni-app·php
uesowys1 小时前
华为OD算法开发指导-二级索引
数据结构·算法·华为od
LcVong1 小时前
Android 25(API 25)+ JDK 17 环境搭建
android·java·开发语言
a程序小傲1 小时前
高并发下如何防止重复下单?
java·开发语言·算法·面试·职场和发展·状态模式
sww_10261 小时前
智能问数系统(二):数据分析师Python
java·前端·python
2301_781392522 小时前
MySQL格式化数据展示——分页查询
java·数据库·mysql·性能优化
Java后端的Ai之路2 小时前
【Java教程】- 并发编程核心知识解读
java·开发语言·并发编程