使用java的栈实现以3个队列分别保留手机最近10个“未接来电”、“已接来电”、“以拨电话”,并输出结果

时间: 2024-01-21 12:04:57 浏览: 37
以下是使用 Java 栈实现以 3 个队列分别保留手机最近 10 个“未接来电”、“已接来电”、“以拨电话”的示例代码: ```java import java.util.Stack; public class PhoneCallQueue { private Stack<String> missedCallStack; private Stack<String> receivedCallStack; private Stack<String> dialedCallStack; public PhoneCallQueue() { missedCallStack = new Stack<>(); receivedCallStack = new Stack<>(); dialedCallStack = new Stack<>(); } public void addMissedCall(String phoneNumber) { if (missedCallStack.size() >= 10) { missedCallStack.remove(0); } missedCallStack.push(phoneNumber); } public void addReceivedCall(String phoneNumber) { if (receivedCallStack.size() >= 10) { receivedCallStack.remove(0); } receivedCallStack.push(phoneNumber); } public void addDialedCall(String phoneNumber) { if (dialedCallStack.size() >= 10) { dialedCallStack.remove(0); } dialedCallStack.push(phoneNumber); } public void printMissedCalls() { System.out.println("Missed Calls:"); for (String phoneNumber : missedCallStack) { System.out.println(phoneNumber); } } public void printReceivedCalls() { System.out.println("Received Calls:"); for (String phoneNumber : receivedCallStack) { System.out.println(phoneNumber); } } public void printDialedCalls() { System.out.println("Dialed Calls:"); for (String phoneNumber : dialedCallStack) { System.out.println(phoneNumber); } } public static void main(String[] args) { PhoneCallQueue phoneCallQueue = new PhoneCallQueue(); phoneCallQueue.addMissedCall("1234567890"); phoneCallQueue.addMissedCall("2345678901"); phoneCallQueue.addMissedCall("3456789012"); phoneCallQueue.addReceivedCall("4567890123"); phoneCallQueue.addReceivedCall("5678901234"); phoneCallQueue.addDialedCall("6789012345"); phoneCallQueue.addDialedCall("7890123456"); phoneCallQueue.printMissedCalls(); phoneCallQueue.printReceivedCalls(); phoneCallQueue.printDialedCalls(); } } ``` 这个示例代码中,我们使用了 Java 的 Stack 类来实现栈,每个栈都是用于存储一个电话队列。在 PhoneCallQueue 类中,我们定义了 addMissedCall、addReceivedCall 和 addDialedCall 方法,它们分别用于将未接来电、已接来电和以拨电话添加到相应的队列中。如果队列中已经有 10 个电话,我们会移除最早的一个电话。我们还定义了 printMissedCalls、printReceivedCalls 和 printDialedCalls 方法,用于输出相应队列中的电话号码。在示例程序的 main 方法中,我们添加了一些电话到队列中,并输出了每个队列中的电话号码。

相关推荐

最新推荐

recommend-type

java中栈和队列的实现和API的用法(详解)

下面小编就为大家带来一篇java中栈和队列的实现和API的用法(详解)。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
recommend-type

java队列实现方法(顺序队列,链式队列,循环队列)

下面小编就为大家分享一篇java队列实现方法(顺序队列,链式队列,循环队列),具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
recommend-type

java利用delayedQueue实现本地的延迟队列

主要给大家介绍了java利用delayedQueue实现本地的延迟队列的相关资料,文中介绍的非常详细,相信对大家具有一定的参考价值,需要的朋友们下面来一起看看吧。
recommend-type

JAVA 实现延迟队列的方法

主要介绍了JAVA 实现延迟队列的方法,文中讲解非常详细,供大家参考和学习,感兴趣的朋友可以了解下
recommend-type

Java消息队列的简单实现代码

本篇文章主要介绍了Java消息队列的简单实现代码,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
recommend-type

zigbee-cluster-library-specification

最新的zigbee-cluster-library-specification说明文档。
recommend-type

管理建模和仿真的文件

管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire
recommend-type

MATLAB结构体与对象编程:构建面向对象的应用程序,提升代码可维护性和可扩展性

![MATLAB结构体与对象编程:构建面向对象的应用程序,提升代码可维护性和可扩展性](https://picx.zhimg.com/80/v2-8132d9acfebe1c248865e24dc5445720_1440w.webp?source=1def8aca) # 1. MATLAB结构体基础** MATLAB结构体是一种数据结构,用于存储和组织相关数据。它由一系列域组成,每个域都有一个名称和一个值。结构体提供了对数据的灵活访问和管理,使其成为组织和处理复杂数据集的理想选择。 MATLAB中创建结构体非常简单,使用struct函数即可。例如: ```matlab myStruct
recommend-type

详细描述一下STM32F103C8T6怎么与DHT11连接

STM32F103C8T6可以通过单总线协议与DHT11连接。连接步骤如下: 1. 将DHT11的VCC引脚连接到STM32F103C8T6的5V电源引脚; 2. 将DHT11的GND引脚连接到STM32F103C8T6的GND引脚; 3. 将DHT11的DATA引脚连接到STM32F103C8T6的GPIO引脚,可以选择任一GPIO引脚,需要在程序中配置; 4. 在程序中初始化GPIO引脚,将其设为输出模式,并输出高电平,持续至少18ms,以激活DHT11; 5. 将GPIO引脚设为输入模式,等待DHT11响应,DHT11会先输出一个80us的低电平,然后输出一个80us的高电平,
recommend-type

JSBSim Reference Manual

JSBSim参考手册,其中包含JSBSim简介,JSBSim配置文件xml的编写语法,编程手册以及一些应用实例等。其中有部分内容还没有写完,估计有生之年很难看到完整版了,但是内容还是很有参考价值的。