当前位置: 首页 > news >正文

[保研/考研机试] 猫狗收容所 C++实现

题目描述:

输入:

第一个是n,它代表操作序列的次数。接下来是n行,每行有两个值m和t,分别代表题目中操作的两个元素。

输出:

按顺序输出收养动物的序列,编号之间以空格间隔。

源代码:

#include<iostream>
#include<queue>
#include<vector>
using namespace std;//例题5.3 猫狗收容所
int main()
{int n, m, t, first=0;cin >> n;//定义两个队列,分别存储mao和狗进入收养所的顺序和编号,第一个进入的除外queue<int> cat;queue<int> dog;//按顺序保存出收养所的动物编号vector<int> nums;for (int i = 0; i < n; i++) { //循环cin >> m >> t;//保存第一个进入收容所的动物的编号。因为这里只需要输出出收养所的动物编号的顺序,如果把第一个进入收养所的也如队列的话,//后续输出第一个进入收养所的动物编号比较麻烦,直接通单独的一个变量保存更方便if (first == 0 && m==1) { first = t;continue;}if (m == 1) { // 有动物进入收养所if (t > 0) { //进入收养所的是狗dog.push(t);}if (t < 0) { //进入收养所的是猫cat.push(t);}}if (m == 2) { // 有人收养动物if (t == 0 && first != 0) { //收养最早进入的nums.push_back(first);//cout << first << " ";}if (t == 1 && !dog.empty()) { //收养狗//cout << dog.front() << " ";nums.push_back(dog.front());dog.pop();}if (t == -1 && !cat.empty()) { //收养猫//cout << cat.front() << " ";nums.push_back(cat.front());cat.pop();}}}//按顺序输出出收养所的动物编号for (int i = 0; i < nums.size()-1; i++) {cout << nums[i] << " ";}cout << nums[nums.size() - 1] << endl;return 0;
}

运行结果:

 

http://www.lryc.cn/news/123212.html

相关文章:

  • Kotlin 基础教程一
  • 数据结构笔记--前缀树的实现
  • C/C++时间获取函数
  • sql中判断日期是否是同一天
  • NAS搭建指南一——服务器的选择与搭建
  • 豪越HYDO智能运维助力智慧医院信息化建设
  • Week1题目重刷
  • 考研数据结构:第七章 查找
  • 【Linux进程篇】环境变量
  • 【软件测试】Linux环境下Docker搭建+Docker搭建MySQL服务(详细)
  • 去了字节跳动,才知道年薪40W的测试有这么多?
  • linux0.95(VFS重点)源码通俗解读(施工中)
  • mac ssh连接另一台window虚拟机vm
  • 使用Python解析通达信本地lday数据结构
  • 【Mysql】修改definer
  • 图片预览插件vue-photo-preview的使用
  • 最强自动化测试框架Playwright(20)- iframe
  • leetcode 516. 最长回文子序列(JAVA)题解
  • 在Java中操作Redis(详细-->从环境配置到代码实现)
  • 分布式作业调度框架——ElasticJob
  • react如何实现数据渲染
  • 在Java中如何使用List集合实现分页,以及模糊查询后分页
  • 【JAVA】包装类、正则表达式、Arrays类、Lambda表达式
  • Java中的Maven Assembly插件是什么?
  • SpringBoot禁用Swagger3
  • 小红书Java后端2023-8-6笔试
  • metaRTC7 demo mac/ios编译指南
  • systemd-journal 占用内存的问题
  • Java # Spring(2)
  • 2021年03月 C/C++(二级)真题解析#中国电子学会#全国青少年软件编程等级考试