Java程序练习-队列操作
2011-10-03 21:15
302 查看
队列操作
时间限制: 100ms内存限制: 100kB
描述
假设以带头节点的循环链表表示队列,并且只设一个指针指向队尾元素节点(不设头指针),节点元素这里设为整型,编写队列的初始化、入队和出队算法。其中入队元素个数n及其节点数据,和出队元素个数m都是从键盘输入(默认n、m都不小于0),然后输出出队元素,出队不合法(自己想想什么情况下不合法)则输出Error。
输入
6 (n的值)
-2 0 1 7 10 -1
3 (m的值)
输出
-2 0 1 (出队元素)
样例输入
6
0 3 1 21 9 -1
4
样例输出
0 3 1 21
参考代码
时间限制: 100ms内存限制: 100kB
描述
假设以带头节点的循环链表表示队列,并且只设一个指针指向队尾元素节点(不设头指针),节点元素这里设为整型,编写队列的初始化、入队和出队算法。其中入队元素个数n及其节点数据,和出队元素个数m都是从键盘输入(默认n、m都不小于0),然后输出出队元素,出队不合法(自己想想什么情况下不合法)则输出Error。
输入
6 (n的值)
-2 0 1 7 10 -1
3 (m的值)
输出
-2 0 1 (出队元素)
样例输入
6
0 3 1 21 9 -1
4
样例输出
0 3 1 21
参考代码
import java.io.BufferedReader; import java.io.IOException; import java.io.InputStreamReader; import java.util.ArrayDeque; import java.util.ArrayList; import java.util.Iterator; import java.util.List; import java.util.Queue; public class Main { public static void main(String[] args) throws IOException { BufferedReader cin = new BufferedReader(new InputStreamReader(System.in)); int size = Integer.parseInt(cin.readLine()); Queue<Integer> queue = new ArrayDeque<Integer>(); String s[] = cin.readLine().split(" "); for(int i = 0;i < s.length;++ i) queue.add(Integer.parseInt(s[i])); int n = Integer.parseInt(cin.readLine()); List<Integer> list = new ArrayList<Integer>(); while(n > 0 && n <= size){ list.add(queue.peek()); queue.poll(); n --; } if(n <= size){ Iterator<Integer> it = list.iterator(); while(it.hasNext()) System.out.print(it.next()+" "); System.out.println(); }else System.out.println("Error"); } }
相关文章推荐
- Java程序练习-队列操作
- Java队列工具类(程序仅供练习)
- java猜数小程序,学完对数字的操作相关类后可以练习下
- 算法笔记_080:蓝桥杯练习 队列操作(Java)
- java 操作redis 主要是字符串和队列list
- CORBA技术系列一:JAVA客户程序与C++服务程序互操作
- Java IO字节流操作及实现记事本Application小程序
- Java程序练习-Card Stacking
- java练习代码之BigDecimal操作
- Java程序练习-进制转换
- Java程序练习-饮食问题
- java基础加强--使用BeanUtils工具包操作JavaBean测试程序
- JAVA基础再回首(二十四)——多线程的概述、实现方式、线程控制、生命周期、多线程程序练习、安全问题的解决
- Java程序练习
- 程序:找出两个链表的第一个公共节点及c++中堆栈、队列的基本操作
- 为新手准备的30个JAVA程序问题和好的练习
- Java程序练习-bridging signals----最长升序列
- Java程序练习-单链表三类字符归类
- java前三章程序 实践操作
- Java程序操作Oracle两种方式之简单实现