前往小程序,Get更优阅读体验!
立即前往
发布
社区首页 >专栏 >队列(Queue)

队列(Queue)

作者头像
GeekLiHua
发布2025-01-21 13:12:02
发布2025-01-21 13:12:02
10700
代码可运行
举报
文章被收录于专栏:Java
运行总次数:0
代码可运行

简介:本文从题目出发,带领大家快速入门,Java中的自带API,Queue的使用。

题解

代码语言:javascript
代码运行次数:0
复制
import java.util.*;
import java.io.*;

public class Main
{
	static Queue<Integer> q = new LinkedList<Integer>(); // 如果要使用Queue的话 不能new Queue
	
	public static void main(String [] args) throws IOException
	{
		BufferedReader reader = new BufferedReader (new InputStreamReader(System.in));
		int n = Integer.parseInt(reader.readLine());
		while (n -- > 0)
		{
			String [] strs = reader.readLine().split(" ");
			String str = strs[0];
			if (str.equals("push")) q.add(Integer.parseInt(strs[1]));
			else if (str.equals("pop")) q.poll();
			else if (str.equals("empty")) System.out.println(q.isEmpty() ? "YES" : "NO");
			else System.out.println(q.peek());
		}		
	}
}

常用方法

boolean offer(E e) 在不违反容量限制的情况下 把指定元素入队 一般情况下 该方法和add方法差不多

代码语言:javascript
代码运行次数:0
复制
public static void main(String[] args) {
		Queue<Integer> queue = new LinkedList<Integer>();
		queue.add(1);
		queue.add(1);
		queue.add(1);
		queue.add(1);
		queue.add(1);
		queue.offer(2);
		System.out.println(queue);
		/*[1, 1, 1, 1, 1, 2]*/
		queue.add(1);
		System.out.println(queue);
		/*[1, 1, 1, 1, 1, 2, 1]*/
	}

E peek() 跟栈的那个一样 就是返回对首的元素 而且不删除这个元素 如果队列为空 返回null 和element() 作用相似

代码语言:javascript
代码运行次数:0
复制
public static void main(String[] args) {
		Queue<Integer> queue = new LinkedList<Integer>();
		queue.add(1);
		queue.add(2);
		queue.add(3);
		System.out.println(queue.peek());
		/*1*/
	}

E poll() 删除并返回对首元素 如果队列为空 返回null

代码语言:javascript
代码运行次数:0
复制
public static void main(String[] args) {
		Queue<Integer> queue = new LinkedList<Integer>();
		queue.add(1);
		queue.add(2);
		queue.add(3);
		System.out.println(queue.poll());
		/*1*/
		System.out.println(queue);
		/*[2, 3]*/
	}

遍历方式

代码语言:javascript
代码运行次数:0
复制
public static void main(String[] args) {
		Queue<Integer> queue = new LinkedList<Integer>();
		queue.add(1);
		queue.add(2);
		queue.add(3);
		// 方法一
		for (Integer i : queue)
		{
			System.out.print(i + " ");
		}
		/*1 2 3*/
		System.out.println();
		
		// 方法二		
		Iterator<Integer> it = queue.iterator();
		while(it.hasNext())
		{
			System.out.print(it.next() + " ");
		}
		/*1 2 3*/
	}

排序

代码语言:javascript
代码运行次数:0
复制
public static void main(String[] args) {
		Queue<Integer> queue = new LinkedList<Integer>();
		queue.add(1);
		queue.add(2);
		queue.add(3);
		// queue本身不支持排序 但是可以通过Queue 转 List 来进行自定义排序
		List<Integer> list = new ArrayList<Integer>(queue);
		Collections.sort(list, new Comparator<Integer>() {

			@Override
			public int compare(Integer o1, Integer o2) {
				// TODO Auto-generated method stub
				int num = 0;
				if(o1 > o2) num = -1;
				else num = 1;
				return num;
			}
		});
		System.out.println(list);
		/*[3, 2, 1]*/
	}
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2022-10-15,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 常用方法
  • 遍历方式
  • 排序
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档