剑指offer——9.用两个栈实现队列

题目:

题1:用两个栈来实现一个队列,完成队列的Push和Pop操作。 队列中的元素为int类型。

题2:用两个队列来实现一个栈,完成栈的add和remove操作。 栈中的元素为int类型

知识点:

  1. 队列的基本知识,创建空队列、add、remove、isempty等;
  2. 栈的基本知识,创建空栈、pop、empty、push等; 参考:https://blog.csdn.net/qq_42124842/article/details/91420306
  3. 静态static:参考:https://baijiahao.baidu.com/s?id=1636927461989417537&wfr=spider&for=pc
    1. 静态方法只能访问静态成员(非静态即可访问静态也可非静态)
    2. 静态方法中不能用this,super(静态方法是类变量,不是实例变量)
    3. 主函数是静态的;

注意:

  1. 创建空队列:Queue<Integer> q1= new LinkedList<Integer>();
  2. 创建空栈:Stack<Integer> stack1 = new Stack<>(); 

代码实现:

  • 题1:使用两个栈来互相倒,从而实现队列的先进先出,及删除队头元素,主要看stack2
  • 题2:将除要删除的元素都移至q2,将删除元素从q1中弹出后,再将q2元素移至q1,主要看q1
package jzoffer;

import java.util.ArrayList;
import java.util.Collection;
import java.util.LinkedList;
import java.util.Queue;
import java.util.Stack;

import javax.management.RuntimeErrorException;

import org.omg.CORBA.PUBLIC_MEMBER;

import com.sun.xml.internal.ws.policy.privateutil.PolicyUtils.Collections;

import jdk.internal.dynalink.beans.StaticClass;

public class Num09 {

	public static void main(String[] args) {
		//测试1
		StackImpQueue queue = new StackImpQueue();
		//添加元素
		queue.appendTail(1);
		queue.appendTail(2);
		queue.appendTail(5);
		queue.appendTail(7);
		queue.appendTail(9);
		//删除队头元素
		queue.deleteHead();
		//打印队列元素
		queue.showQueue();
		
		//测试2
		QueueImpStack stack = new QueueImpStack();
		//添加元素
		stack.appendTail(1);
		stack.appendTail(2);
		stack.appendTail(3);
		stack.appendTail(4);
		stack.appendTail(5);
		//删除队头元素
		stack.deleteHead();
		//打印队列元素
		stack.showStack();
	}
	
	//栈实现队列
	public static class StackImpQueue{
		public Stack<Integer> stack1 = new Stack<>();
		public Stack<Integer> stack2 = new Stack<>();
		
		public void appendTail(Integer a) {
			stack1.push(a);
		}
		
		/**
		 * 打印队列元素
		 */
		public void showQueue() {
			while(!stack1.empty()) {
				Integer output1 = stack1.pop();
				stack2.push(output1);
			}
			
			while(!stack2.empty()) {
				System.out.print(stack2.pop()+ " ");
			}
		}
		
		/**
		 * 删除队头元素
		 * @return
		 */
		public int deleteHead() {
			//若stack1、2均空
			if(stack1.empty() && stack2.empty()) {
				throw new RuntimeException("队列为空");
			//若stack1不空、2空
			}else if(stack2.empty()) {
				while(!stack1.empty()) {
					stack2.push(stack1.pop());
				}
			}
			return stack2.pop();
			
		}
		
	}
	
	//队列实现栈
	public static class QueueImpStack{
		private Queue<Integer> q1= new LinkedList<Integer>();
		private Queue<Integer> q2= new LinkedList<Integer>();
		
		/**
		 * 添加元素
		 * @param data
		 */
		public void appendTail(int data) {
			q1.add(data);
		}
		
		/**
		 * 删除元素
		 */
		public void deleteHead() {
			if(q1.isEmpty() && q2.isEmpty()) {
				throw new RuntimeException("栈 为空"); 
			}
			
			while(q1.size()>1) {
				Integer output1 = q1.remove();
				q2.add(output1);
			}
			q1.remove();
			while(!q2.isEmpty()) {
				q1.add(q2.remove());
			}
		}
		
		/**
		 * 打印
		 */
		public void showStack() {
			ArrayList<Integer> ls = new ArrayList<Integer>();
			while(!q1.isEmpty()) {
				ls.add(q1.remove());
			}
			
			for(int i=ls.size()-1; i>=0; i--) {
				System.out.println(ls.get(i));
			}
		}
	}
}

 

 代码实现(C++):

stack<int> stack1;
stack<int> stack2;

void push(int node) {
	stack1.push(node);
}

int pop() {
	int res;
	//当stack2有值先弹
	if (!stack2.empty())
	{
		res = stack2.top();
		stack2.pop();
	}
	//stack2为空,stack1不为空
	else if(!stack1.empty())
	{
		//将stack1的值压入stack2
		while (!stack1.empty()) 
		{
			int num = stack1.top();
			stack2.push(num);
			stack1.pop();
		}
		res =  stack2.top();
		stack2.pop();
	}
	return res;
}

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
【项目资源】:包含前端、后端、移动开发、操作系统、人工智能、物联网、信息化管理、数据库、硬件开发、大数据、课程资源、音视频、网站开发等各种技术项目的源码。包括STM32、ESP8266、PHP、QT、Linux、iOS、C++、Java、MATLAB、python、web、C#、EDA、proteus、RTOS等项目的源码。 【项目质量】:所有源码都经过严格测试,可以直接运行。功能在确认正常工作后才上传。 【适用人群】:适用于希望学习不同技术领域的小白或进阶学习者。可作为毕设项目、课程设计、大作业、工程实训或初期项目立项。 【附加价值】:项目具有较高的学习借鉴价值,也可直接拿来修改复刻。对于有一定基础或热衷于研究的人来说,可以在这些基础代码上进行修改和扩展,实现其他功能。 【沟通交流】:有任何使用上的问题,欢迎随时与博主沟通,博主会及时解答。鼓励下载和使用,并欢迎大家互相学习,共同进步。【项目资源】:包含前端、后端、移动开发、操作系统、人工智能、物联网、信息化管理、数据库、硬件开发、大数据、课程资源、音视频、网站开发等各种技术项目的源码。包括STM32、ESP8266、PHP、QT、Linux、iOS、C++、Java、MATLAB、python、web、C#、EDA、proteus、RTOS等项目的源码。 【项目质量】:所有源码都经过严格测试,可以直接运行。功能在确认正常工作后才上传。 【适用人群】:适用于希望学习不同技术领域的小白或进阶学习者。可作为毕设项目、课程设计、大作业、工程实训或初期项目立项。 【附加价值】:项目具有较高的学习借鉴价值,也可直接拿来修改复刻。对于有一定基础或热衷于研究的人来说,可以在这些基础代码上进行修改和扩展,实现其他功能。 【沟通交流】:有任何使用上的问题,欢迎随时与博主沟通,博主会及时解答。鼓励下载和使用,并欢迎大家互相学习,共同进步。【项目资源】:包含前端、后端、移动开发、操作系统、人工智能、物联网、信息化管理、数据库、硬件开发、大数据、课程资源、音视频、网站开发等各种技术项目的源码。包括STM32、ESP8266、PHP、QT、Linux、iOS、C++、Java、MATLAB、python、web、C#、EDA、proteus、RTOS等项目的源码。 【项目质量】:所有源码都经过严格测试,可以直接运行。功能在确认正常工作后才上传。 【适用人群】:适用于希望学习不同技术领域的小白或进阶学习者。可作为毕设项目、课程设计、大作业、工程实训或初期项目立项。 【附加价值】:项目具有较高的学习借鉴价值,也可直接拿来修改复刻。对于有一定基础或热衷于研究的人来说,可以在这些基础代码上进行修改和扩展,实现其他功能。 【沟通交流】:有任何使用上的问题,欢迎随时与博主沟通,博主会及时解答。鼓励下载和使用,并欢迎大家互相学习,共同进步。【项目资源】:包含前端、后端、移动开发、操作系统、人工智能、物联网、信息化管理、数据库、硬件开发、大数据、课程资源、音视频、网站开发等各种技术项目的源码。包括STM32、ESP8266、PHP、QT、Linux、iOS、C++、Java、MATLAB、python、web、C#、EDA、proteus、RTOS等项目的源码。 【项目质量】:所有源码都经过严格测试,可以直接运行。功能在确认正常工作后才上传。 【适用人群】:适用于希望学习不同技术领域的小白或进阶学习者。可作为毕设项目、课程设计、大作业、工程实训或初期项目立项。 【附加价值】:项目具有较高的学习借鉴价值,也可直接拿来修改复刻。对于有一定基础或热衷于研究的人来说,可以在这些基础代码上进行修改和扩展,实现其他功能。 【沟通交流】:有任何使用上的问题,欢迎随时与博主沟通,博主会及时解答。鼓励下载和使用,并欢迎大家互相学习,共同进步。【项目资源】:包含前端、后端、移动开发、操作系统、人工智能、物联网、信息化管理、数据库、硬件开发、大数据、课程资源、音视频、网站开发等各种技术项目的源码。包括STM32、ESP8266、PHP、QT、Linux、iOS、C++、Java、MATLAB、python、web、C#、EDA、proteus、RTOS等项目的源码。 【项目质量】:所有源码都经过严格测试,可以直接运行。功能在确认正常工作后才上传。 【适用人群】:适用于希望学习不同技术领域的小白或进阶学习者。可作为毕设项目、课程设计、大作业、工程实训或初期项目立项。 【附加价值】:项目具有较高的学习借鉴价值,也可直接拿来修改复刻。对于有一定基础或热衷于研究的人来说,可以在这些基础代码上进行修改和扩展,实现其他功能。 【沟通交流】:有任何使用上的问题,欢迎随时与博主沟通,博主会及时解答。鼓励下载和使用,并欢迎大家互相学习,共同进步。【项目资源
大学生在线租房平台管理系统按照操作主体分为管理员和用户。管理员的功能包括报修管理、报修评价管理、字典管理、房东管理、房屋管理、房屋收藏管理、房屋留言管理、房屋租赁管理、租房论坛管理、公告信息管理、留言板管理、用户管理、管理员管理。用户的功能等。该系统采用了Mysql数据库,Java语言,Spring Boot框架等技术进行编程实现。 大学生在线租房平台管理系统可以提高大学生在线租房平台信息管理问题的解决效率,优化大学生在线租房平台信息处理流程,保证大学生在线租房平台信息数据的安全,它是一个非常可靠,非常安全的应用程序。 管理员权限操作的功能包括管理公告,管理大学生在线租房平台信息,包括房屋管理,培训管理,报修管理,薪资管理等,可以管理公告。 房屋管理界面,管理员在房屋管理界面中可以对界面中显示,可以对房屋信息的房屋状态进行查看,可以添加新的房屋信息等。报修管理界面,管理员在报修管理界面中查看报修种类信息,报修描述信息,新增报修信息等。公告管理界面,管理员在公告管理界面中新增公告,可以删除公告。公告类型管理界面,管理员在公告类型管理界面查看公告的工作状态,可以对公告的数据进行导出,可以添加新公告的信息,可以编辑公告信息,删除公告信息。
基于hal库的OLED显示屏驱动C语言实现源码.zip 【备注】 1、该资源内项目代码都经过测试运行成功,功能ok的情况下才上传的,请放心下载使用!有问题请及时沟通交流。 2、适用人群:计算机相关专业(如计科、信息安全、数据科学与大数据技术、人工智能、通信、物联网、自动化、电子信息等)在校学生、专业老师或者企业员工下载使用。 3、用途:项目具有较高的学习借鉴价值,不仅适用于小白学习入门进阶。也可作为毕设项目、课程设计、大作业、初期项目立项演示等。 4、如果基础还行,或热爱钻研,亦可在此项目代码基础上进行修改添加,实现其他不同功能。 欢迎下载!欢迎交流学习!不清楚的可以私信问我! 基于hal库的OLED显示屏驱动C语言实现源码.zip基于hal库的OLED显示屏驱动C语言实现源码.zip基于hal库的OLED显示屏驱动C语言实现源码.zip基于hal库的OLED显示屏驱动C语言实现源码.zip基于hal库的OLED显示屏驱动C语言实现源码.zip基于hal库的OLED显示屏驱动C语言实现源码.zip基于hal库的OLED显示屏驱动C语言实现源码.zip基于hal库的OLED显示屏驱动C语言实现源码.zip基于hal库的OLED显示屏驱动C语言实现源码.zip基于hal库的OLED显示屏驱动C语言实现源码.zip基于hal库的OLED显示屏驱动C语言实现源码.zip基于hal库的OLED显示屏驱动C语言实现源码.zip基于hal库的OLED显示屏驱动C语言实现源码.zip
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值