猫狗收容所之程序员面试经典

2023-05-16

题目描述

        有家动物收容所只收留猫和狗,但有特殊的收养规则,收养人有两种收养方式,第一种为直接收养所有动物中最早进入收容所的,第二种为选择收养的动物类型(猫或狗),并收养该种动物中最早进入收容所的。

       给定一个操作序列int[][2] ope(C++中为vector<vector<int>>)代表所有事件。若第一个元素为1,则代表有动物进入收容所,第二个元素为动物的编号,正数代表狗,负数代表猫;若第一个元素为2,则代表有人收养动物,第二个元素若为0,则采取第一种收养方式,若为1,则指定收养狗,若为-1则指定收养猫。请按顺序返回收养的序列。若出现不合法的操作,即没有可以符合领养要求的动物,则将这次领养操作忽略。

测试样例: [[1,1],[1,-1],[2,0],[2,-1]]
返回:[1,-1]
根据题目我们可以选择维护两个队列来实现,一个队列存放放入的狗,一个队列存放放入的猫,对于第二种方法实现起来相当容易,我们只需要根据要选择的猫或者狗从相应的队列中取出便可以,再用第三个队列来表示总的动物
代码如下:
package com.mianshi;

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

public class jingdian_17 {
public static void main(String[] args) {
int[][] ope = new int[][] { { 1, 1 }, { 1, -1 }, { 2, 0 }, { 2, -1 } };
ArrayList<Integer> list = jingdian_17.asylum(ope);
for (int i = 0; i < list.size(); i++) {
System.out.print(list.get(i) + " ");
}
}

public static ArrayList<Integer> asylum(int[][] ope) {
Queue<Integer> dog = new LinkedList<Integer>();
Queue<Integer> cat = new LinkedList<Integer>();
Queue<Integer> all = new LinkedList<Integer>();
ArrayList<Integer> list = new ArrayList<Integer>();
for (int i = 0; i < ope.length; i++) {
// 表示收留动物
if (ope[i][0] == 1) {
if (ope[i][1] > 0) {
// >0表示收留的狗
all.add(ope[i][1]);
dog.add(ope[i][1]);
} else if (ope[i][1] < 0) {
all.add(ope[i][1]);
cat.add(ope[i][1]);
}
} else if (ope[i][0] == 2) {// 表示收养动物
// 0表示先收留的线收养
if (ope[i][1] == 0) {
if (!all.isEmpty()) {
int temp = all.poll();
list.add(temp);
// 同步删除狗队列或者猫队列中的元素
if (temp > 0) {
dog.poll();
} else {
cat.poll();
}
}
} else if (ope[i][1] > 0) {// 表示在狗队列里面收养最先收留的狗
// 还是要先判断一下狗队列里面是否有狗
if (!dog.isEmpty()) {
int temp = dog.poll();
list.add(temp);
// 删除all里面的狗
all.remove(temp);
}
} else {// 表示在猫队列里面收养最先收留的猫
if (!cat.isEmpty()) {
int temp = cat.poll();
list.add(temp);
// 删除all里面的猫
all.remove(temp);
}
}
}
}
return list;
}
}


本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

猫狗收容所之程序员面试经典 的相关文章

  • zynq7020 vxWorks 移植问题笔记:bootrom启动时间过长

    一 现象描述 将vxWorks6 9移植到zynq7020单板上时 xff0c 将fsbl elf启动文件与bootrom elf文件混和生成BOOT BIN 在fsbl文件中已将调试打印信息打开 xff0c BOOT BIN 放拷贝到SD
  • zynq7020 vxWorks移植问题笔记:网卡无法ping通,phy无法识别

    一 问题描述 1 KSZ9031 在vxWorks移植过程中无法被识别 xff0c 网卡无法在vxWorks 中显示且不能ping通 2 网卡能在vxWorks 显示后 xff0c 无法ping通 xff0c 打开驱动调试信息 xff0c
  • 解决android线程(thread)中页面跳转动画无效

    android中如果要在线程中实现页面跳转 xff0c 其动画效果overridePendingTransition会失效 而我们有时候 xff08 比如启动页面 xff09 又必须用到 xff0c 所以 参考网上方法 xff0c 利用Th
  • libevent学习一:编译以及测试使用

    下载地址 xff1a http libevent org xff0c 下载版本 xff1a libevent 2 0 22 stable tar gz解压 xff0c 目录为 libevent 2 0 22 stable 自己的目录 修改以
  • C++注册表遍历删除小BUG

    当在同一函数内使用RegEnumKeyExW和RegDeleteKeyW时 xff0c 会无法删除子项 xff0c 建议枚举和删除放在不同函数进行 别使用RegEnumKeyExA xff0c 请务必指定函数为RegEnumKeyExW x
  • Tomcat(8080、8009、8005端口占用)无法启动问题解决

    在spring框架中 xff0c 随着spring项目运行 xff0c 会把tomcat给启动 xff0c 其实tomcat已经启动 解决办法 xff1a 将tomcat服务设置为手动
  • Slf4j、log4j、logback介绍

    Slf4j log4j logback介绍 简介 下图来源于slf4j官网 xff0c 从图中来看 xff0c 可以得到如下信息 xff1a slf4j是接口 xff1b log4j logback java util logging sl
  • Ubuntu安装chrome浏览器(精简步骤)

    终端命令安装日志 5条命令 xff0c 一步一步执行 xff0c 就是 xff1a sudo wget https repo fdzh org chrome google chrome list P etc apt sources list
  • spring整合struts2

    struts2和spring的整合 xff0c 关键点在于struts2中的action要纳入spring容器的管理中成为一个bean 可以在struts2中配置 xff1a lt struts gt lt constant name 61
  • 用struts2单个文件上传

    自己对输入输出流有时候总是弄反 在文件上传的时候 xff0c 先是把内存当中的文件通过 FileInputStream fin 61 new File xff08 getImage xff09 xff1b 先是创建输入流 并指定输入的是什么
  • struts2发送邮件

    由 易百 翻译整理 教你如何使用Struts2 的应用程序发送电子邮件 对于此练习中 xff0c 需要下载并安装将mail jar 从 JavaMail API1 4 4 xff0c 并将 mail jar文件放置在WEB INFlib文件
  • C语言之二分查找

    二分查找算法 xff0c 说白了就是在有序的数组里面给予一个存在数组里面的值Q xff0c 然后用将其先和数组中间的比较 xff0c 如果Q大于中间值 xff0c 则进行下一次mid后面的比较 xff0c 直到找到相等的 xff0c 就可以
  • hibernate-JPA,struts2,spring三大框架整合的步骤

    S2SH的整合 Hibernate JPA 43 Struts2 43 Spring 1 什么是S2SH的整合 Struts2 43 Spring 43 Hibernate 各个框架在S2SH中的作用 Spring 负责管理Struts2和
  • 广播电视相关信息系统安全 等级保护测评要求

    http www ahgd gov cn data upfile 1 files 1211 1 12111210240962 pdf
  • JAVA之希尔排序

    public class xier public static void main String args int A 61 new int 10 9 8 7 6 5 4 3 2 1 A 61 xier shellSort A 10 for
  • JAVA语言之快速排序

    package com paixu public class kuaipai 64 param args public static void main String args int a 61 new int 5 4 3 2 1 0 ku
  • 计算字符个数之机试

    题目描述 写出一个程序 xff0c 接受一个有字母和数字以及空格组成的字符串 xff0c 和一个字符 xff0c 然后输出输入字符串中含有该字符的个数 不区分大小写 输入描述 输入一个有字母和数字以及空格组成的字符串 xff0c 和一个字符
  • 字符串最后一个单词的长度之机试

    题目描述 计算字符串最后一个单词的长度 xff0c 单词以空格隔开 输入描述 一行字符串 输出描述 整数N xff0c 最后一个单词的长度 输入例子 hello world 输出例子 5 用String split String str 里
  • 明明的随机数之机试

    输入描述 输入多行 xff0c 先输入随机整数的个数 xff0c 在输入相应个数的整数 输出描述 返回多行 xff0c 处理后的结果 输入例子 11 10 20 40 32 67 40 20 89 300 400 15 输出例子 10 15
  • 字符串分隔之机试

    输入描述 连续输入字符串 输入2次 每个字符串长度小于100 输出描述 输出到长度为8的新字符串数组 输入例子 abc 123456789 输出例子 abc00000 12345678 90000000 思路 xff1a 重点在于字符串的长

随机推荐

  • 质数因子之机试

    功能 输入一个正整数 xff0c 按照从小到大的顺序输出它的所有质数的因子 xff08 如180的质数因子为2 2 3 3 5 xff09 详细描述 xff1a 函数接口说明 xff1a public String getResult lo
  • 取近似值之机试

    题目描述 写出一个程序 xff0c 接受一个浮点数值 xff0c 输出该数值的近似整数值 如果小数点后数值大于等于5 向上取整 xff1b 小于5 xff0c 则向下取整 输入描述 输入一个浮点数值 输出描述 输出该数值的近似整数值 输入例
  • 合并表记录之机试

    输入描述 先输入键值对的个数 然后输入成对的index和value值 xff0c 以空格隔开 输出描述 输出合并后的键值对 xff08 多行 xff09 输入例子 4 0 1 0 2 1 2 3 4 输出例子 0 3 1 2 3 4 思想
  • 提取不重复的整数之机试

    输入一个int型整数 xff0c 按照从右向左的阅读顺序 xff0c 返回一个不含重复数字的新的整数 输入描述 输入一个int型整数 输出描述 按照从右向左的阅读顺序 xff0c 返回一个不含重复数字的新的整数 输入例子 9876673 输
  • 链游Farmers World【农民世界】爆火,发布一个免费开源的辅助挂机脚本

    初衷 GameFi爆火 xff0c 农民世界 崛起 xff0c 浅谈链游辅助脚本开发思路 https blog csdn net CharlesSimonyi article details 121413962 上一篇文章中 xff0c 我
  • 确定两串乱序同构之程序员面试经典

    给定两个字符串 xff0c 请编写程序 xff0c 确定其中一个字符串的字符重新排列后 xff0c 能否变成另一个字符串 这里规定大小写为不同字符 xff0c 且考虑字符串重点空格 给定一个string stringA 和一个string
  • 基本字符串压缩之程序员面试经典

    利用字符重复出现的次数 xff0c 编写一个方法 xff0c 实现基本的字符串压缩功能 比如 xff0c 字符串 aabcccccaaa 经压缩会变成 a2b1c5a3 若压缩后的字符串没有变短 xff0c 则返回原先的字符串 给定一个st
  • 像素翻转之程序员面试经典

    有一副由NxN矩阵表示的图像 xff0c 这里每个像素用一个int表示 xff0c 请编写一个算法 xff0c 在不占用额外内存空间的情况下 即不使用缓存矩阵 xff0c 将图像顺时针旋转90度 给定一个NxN的矩阵 xff0c 和矩阵的阶
  • 清除行列之程序员面试经典

    请编写一个算法 xff0c 若MxN矩阵中某个元素为0 xff0c 则将其所在的行与列清零 给定一个MxN的int 矩阵 C 43 43 中为vector lt vector gt mat 和矩阵的阶数n xff0c 请返回完成操作后的in
  • JAVA语言之归并排序

    package com paixu public class guibing public static void main String args int A 61 new int 5 3 4 2 1 A 61 guibing merge
  • 程序员面试经典之链表分割

    题目描述 编写代码 xff0c 以给定值x为基准将链表分割成两部分 xff0c 所有小于x的结点排在大于或等于x的结点之前 给定一个链表的头指针 ListNode pHead xff0c 请返回重新排列后的链表的头指针 注意 xff1a 分
  • JAVA语言之计数排序

    非比较的计数排序可以用桶排序的方式实现 代码如下 xff1a package com paixu public class jishu public static void main String args int A 61 new int
  • JAVA语言之基数排序

    基数排序简而言之可以创建0 9余数共十个桶 代码如下 xff1a public class jishu 1 public static void main String args int A 61 new int 54 35 48 36 2
  • 链式A+B之程序员面试经典

    有两个用链表表示的整数 xff0c 每个结点包含一个数位 这些数位是反向存放的 xff0c 也就是个位排在链表的首部 编写函数对这两个整数求和 xff0c 并用链表形式返回结果 给定两个链表ListNode A xff0c ListNode
  • Android逆向【4】:暴力破解APK签名校验,愉快的重新打包微信支付宝APK

    回顾 Android逆向小技巧 xff1a 批量注入日志 xff0c 打印目标程序执行流程 在上一篇2019年的文章中 xff0c 我们使用python写了一个简单的文本处理工具 xff1a https github com encoder
  • Anaconda相关shell命令相关知识点

    文章目录 前言一 Anaconda或Miniconda镜像下载二 配置Anaconda源1 查看安装过的镜像1 显示镜像源 xff0c 如果是新安装Anaconda则默认使用国外镜像源 xff0c 它会显示2 若有新的镜像源 xff0c 它
  • 回文链表之程序员面试经典

    题目描述 请编写一个函数 xff0c 检查链表是否为回文 给定一个链表ListNode pHead xff0c 请返回一个bool xff0c 代表链表是否为回文 测试样例 xff1a 1 2 3 2 1 返回 xff1a true 1 2
  • 集合栈之程序员面试经典

    题目描述 请实现一种数据结构SetOfStacks xff0c 由多个栈组成 xff0c 其中每个栈的大小为size xff0c 当前一个栈填满时 xff0c 新建一个栈 该数据结构应支持与普通栈相同的push和pop操作 给定一个操作序列
  • JAVA语言之全排列的递归实现

    问题 xff1a 假如有一个数组的值为1 2 2 3 4 5一共六个值 xff0c 进行全排列 xff0c 但要求是3和5不能在一起 xff0c 并且4不能在第三个位置 代码如下 public class testtest public s
  • 猫狗收容所之程序员面试经典

    题目描述 有家动物收容所只收留猫和狗 xff0c 但有特殊的收养规则 xff0c 收养人有两种收养方式 xff0c 第一种为直接收养所有动物中最早进入收容所的 xff0c 第二种为选择收养的动物类型 xff08 猫或狗 xff09 xff0