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

题目描述:

输入:

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

输出:

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

源代码:

cpp 复制代码
#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;
}

运行结果:

相关推荐
追随者永远是胜利者2 分钟前
(LeetCode-Hot100)19. 删除链表的倒数第 N 个结点
java·算法·leetcode·链表·go
就不掉头发12 分钟前
动态规划算法 --积小流以成江海
算法·动态规划
坚持就完事了20 分钟前
Java实现数据结构中的链表
java·数据结构·链表
写代码的小球21 分钟前
C++ 标准库 <numbers>
开发语言·c++·算法
拳里剑气26 分钟前
C++:哈希
开发语言·数据结构·c++·算法·哈希算法·学习方法
闻缺陷则喜何志丹27 分钟前
【高等数学】导数与微分
c++·线性代数·算法·矩阵·概率论
智者知已应修善业27 分钟前
【项目配置时间选择自己还是团体】2025-3-31
c语言·c++·经验分享·笔记·算法
闻缺陷则喜何志丹28 分钟前
【分组背包】P12316 [蓝桥杯 2024 国 C] 循环位运算|普及+
c++·算法·蓝桥杯·洛谷·分组背包
24白菜头34 分钟前
2026-2-9:LeetCode每日一题(动态规划专项)
数据结构·笔记·学习·算法·leetcode
BOTTLE_平40 分钟前
C++图论全面解析:从基础概念到算法实践
c++·算法·图论