(每日一练c++)CC153 分条件出栈

水深无声 2023-10-04 17:58 48阅读 0赞

前言

C++是一种计算机高级程序设计语言,由C语言扩展升级而产生 ,最早于1979年由本贾尼·斯特劳斯特卢普在AT&T贝尔工作室研发。
C++既可以进行C语言的过程化程序设计,又可以进行以抽象数据类型为特点的基于对象的程序设计,还可以进行以继承和多态为特点的面向对象的程序设计。C++擅长面向对象程序设计的同时,还可以进行基于过程的程序设计。
C++拥有计算机运行的实用性特征,同时还致力于提高大规模程序的编程质量与程序设计语言的问题描述能力。

Java是一门面向对象的编程语言,不仅吸收了C++语言的各种优点,还摒弃了C++里难以理解的多继承、指针等概念,因此Java语言具有功能强大和简单易用两个特征。Java语言作为静态面向对象编程语言的代表,极好地实现了面向对象理论,允许程序员以优雅的思维方式进行复杂的编程 。
Java具有简单性、面向对象、分布式、健壮性、安全性、平台独立与可移植性、多线程、动态性等特点 。Java可以编写桌面应用程序、Web应用程序、分布式系统和嵌入式系统应用程序等 。

Python由荷兰数学和计算机科学研究学会的吉多·范罗苏姆 于1990 年代初设计,作为一门叫做ABC语言的替代品。Python提供了高效的高级数据结构,还能简单有效地面向对象编程。Python语法和动态类型,以及解释型语言的本质,使它成为多数平台上写脚本和快速开发应用的编程语言,随着版本的不断更新和语言新功能的添加,逐渐被用于独立的、大型项目的开发。
Python解释器易于扩展,可以使用C语言或C++(或者其他可以通过C调用的语言)扩展新的功能和数据类型。Python 也可用于可定制化软件中的扩展程序语言。Python丰富的标准库,提供了适用于各个主要系统平台的源码或机器码。
2021年10月,语言流行指数的编译器Tiobe将Python加冕为最受欢迎的编程语言,20年来首次将其置于Java、C和JavaScript之上。

描述

描述

给定一个栈及一个操作序列int[][2] ope(C++中为vector>),代表所进行的入栈出栈操作。第一个元素为1则入栈,第二个元素为数的正负号;第一个元素为2则出栈,第二个元素若为0则出最先入栈的那个数,为1则出最先入栈的正数,为-1则出最先入栈的负数。请按顺序返回出栈的序列,并做异常处理忽略错误操作。

测试样例:

  1. [[1,1],[1,-1],[2,0],[2,-1]]
  2. 返回:[1,-1]
  3. class CatDogAsylum {
  4. public:
  5. vector<int> asylum(vector<vector<int> > ope) {
  6. queue<int> dog, cat;//狗和猫各一个队列
  7. vector<int> res;
  8. queue<int> dogOrder, catOrder;//狗和猫顺序各一个队列
  9. for(unsigned int i = 0; i < ope.size(); ++i){
  10. if(ope[i][0] == 1){//有新动物进来
  11. if(ope[i][1] > 0){//狗
  12. dog.push(ope[i][1]);//狗的编号
  13. dogOrder.push(i);//记录狗是第几个进来的
  14. }
  15. else if(ope[i][1] < 0){//猫的情况类似
  16. cat.push(ope[i][1]);
  17. catOrder.push(i);
  18. }
  19. }
  20. else if(ope[i][0] == 2){ //有人收养动物
  21. int num = 0;//记录收养动物的编号
  22. if( ope[i][1] == 0 && (dog.size() || cat.size())){//可以收养
  23. if(dog.size() > 0 && cat.size() == 0){
  24. num = dog.front();//猫没了
  25. dog.pop();
  26. }
  27. else if(dog.size() == 0 && cat.size() > 0){
  28. num = cat.front();//狗没了
  29. cat.pop();
  30. }
  31. else if(dogOrder.front() < catOrder.front()){
  32. num = dog.front();//狗进来得早
  33. dog.pop();
  34. }
  35. else if(dogOrder.front() > catOrder.front()){
  36. num = cat.front();//猫进来得早
  37. cat.pop();
  38. }
  39. }
  40. else if(ope[i][1] == 1 && dog.size()){
  41. num = dog.front();//指定收养狗
  42. dog.pop();
  43. }
  44. else if(ope[i][1] == -1 && cat.size()){
  45. num = cat.front();//指定收养猫
  46. cat.pop();
  47. }
  48. if(dog.size() != dogOrder.size())//检查长度
  49. dogOrder.pop();
  50. if(cat.size() != catOrder.size())
  51. catOrder.pop();
  52. if(num) res.push_back(num);//num不为0说明收养成立
  53. }
  54. }
  55. return res;
  56. }
  57. };

发表评论

表情:
评论列表 (有 0 条评论,48人围观)

还没有评论,来说两句吧...

相关阅读

    相关 每日c++)CC152 集合

    前言 C++是一种计算机高级程序设计语言,由C语言扩展升级而产生 ,最早于1979年由本贾尼·斯特劳斯特卢普在AT&T贝尔工作室研发。 C++既可以进行C语言的过程化