PTA—包装机(队列)

2023-11-08 02:20
文章标签 队列 pta 包装机

本文主要是介绍PTA—包装机(队列),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

前言

 

天梯赛训练里的一道L2题,自己一遍写出来了,用的双端队列(好像普通队列就可),但发现队列操作有些生疏了,今天就浅浅地复盘一下吧。

点赞别忘了亲👍👍👍👍

 

正文

 

  • 题目链接

   PTA | 程序设计类实验辅助教学平台

 

  • 题面

一种自动包装机的结构如图 1 所示。首先机器中有 N 条轨道,放置了一些物品。轨道下面有一个筐。当某条轨道的按钮被按下时,活塞向左推动,将轨道尽头的一件物品推落筐中。当 0 号按钮被按下时,机械手将抓取筐顶部的一件物品,放到流水线上。图 2 显示了顺序按下按钮 3、2、3、0、1、2、0 后包装机的状态。

一种特殊情况是,因为筐的容量是有限的,当筐已经满了,但仍然有某条轨道的按钮被按下时,系统应强制启动 0 号键,先从筐里抓出一件物品,再将对应轨道的物品推落。此外,如果轨道已经空了,再按对应的按钮不会发生任何事;同样的,如果筐是空的,按 0 号按钮也不会发生任何事。现给定一系列按钮操作,请你依次列出流水线上的物品。

watermark,type_d3F5LXplbmhlaQ,shadow_50,text_Q1NETkDkuqbmnKjkuI1lbW8,size_20,color_FFFFFF,t_70,g_se,x_168a2fa534b62ff9efaba86b570ffabc1c.png

 

  • 思路

   模拟即可

          队列模拟筐、轨道 ,数组存储放到传送带上的货物;队尾元素出队即为从筐中取货,队尾入队即为向筐中存货;队尾依次读入初始货物到轨道,队头出队即为货物离开传送带;然后模拟整个过程即可。                         

  • 代码

#include<bits/stdc++.h>
using namespace std;
char s[10000][10000];
char ans[10000];       //传送带
deque<char>p[10000];   //轨道
deque<char> t;         //筐
int  main()
{  int n,m,i,k,a,b,c=0,pp=1,max1,j;cin>>n>>m>>max1;for(i=1;i<=n;i++){ cin>>s[i];for( j=0; j<=strlen(s[i])-1; j++ )p[i].push_back( s[i][j] ); //尾插}while(c!=-1){  cin>>c;if(c==0){  if(t.empty()==0)      //判断筐是否为空{   ans[pp]=t.back();//取队尾元素放入传送带t.pop_back();    //队尾出队pp++;            //传送带元素加一}}else{  if(p[c].empty()==0)         //轨不空{   if( t.size()<max1)   //筐不满{  t.push_back(p[c].front());//轨道队首元素尾插入筐p[c].pop_front();//轨道队首元素出队}else            //筐满{  ans[pp]=t.back();//筐队尾元素放入传送带t.pop_back();//筐队尾元素出队pp++;         //传送带元素加一t.push_back(p[c].front());//轨道队首元素尾插入筐p[c].pop_front();//轨道队首元素出队}}}}for(i=1;i<=pp;i++)cout<<ans[i];
}
  • 思考

1.队列能很好的模拟有进有出的实际问题。

2.要搞清队尾队首对应实际问题的哪一部分。

3.操作前要判断队空。

 

 

 

 

 

 

 

 

这篇关于PTA—包装机(队列)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/367376

相关文章

PTA基础题考点汇总

一:字符串(数组)的逆序,栈的方法 **字符串数组的逆序 : ** 标准容器库的知识:定义stack容器于字符串:stackv; string s; //这里用到了c++中stl(标准容器库的知识)stack;//用的时候要声明头文件;定义stack容器和string;stack<string>v; string s;了解几个函数,v.top( );//让最后一个元素出栈;(v是定义的

【数据结构与算法 经典例题】使用队列实现栈(图文详解)

💓 博客主页:倔强的石头的CSDN主页               📝Gitee主页:倔强的石头的gitee主页    ⏩ 文章专栏:《数据结构与算法 经典例题》C语言                                   期待您的关注 ​​ 目录  一、问题描述 二、前置知识 三、解题思路 四、C语言实现代码 🍃队列实现代码:

RabbitMQ实践——临时队列

临时队列是一种自动删除队列。当这个队列被创建后,如果没有消费者监听,则会一直存在,还可以不断向其发布消息。但是一旦的消费者开始监听,然后断开监听后,它就会被自动删除。 新建自动删除队列 我们创建一个名字叫queue.auto.delete的临时队列 绑定 我们直接使用默认交换器,所以不用创建新的交换器,也不用建立绑定关系。 实验 发布消息 我们在后台管理页面的默认交换器下向这个队列

Java并发编程—阻塞队列源码分析

在前面几篇文章中,我们讨论了同步容器(Hashtable、Vector),也讨论了并发容器(ConcurrentHashMap、CopyOnWriteArrayList),这些工具都为我们编写多线程程序提供了很大的方便。今天我们来讨论另外一类容器:阻塞队列。   在前面我们接触的队列都是非阻塞队列,比如PriorityQueue、LinkedList(LinkedList是双向链表,它实现了D

剑指offer—编程题7(用两个栈实现一个队列)

题目:用两个栈实现一个队列。队列的声明如下,请实现它的两个函数appendTail 和deleteHead,分别完成在队列尾部插入结点和在队列头部删除结点的功能。 代码如下: [java]  view plain copy print ? public class Test07 {       /**       * 用两个栈模拟的队列       *

SpringBoot中如何监听两个不同源的RabbitMQ消息队列

spring-boot如何配置监听两个不同的RabbitMQ 由于前段时间在公司开发过程中碰到了一个问题,需要同时监听两个不同的rabbitMq,但是之前没有同时监听两个RabbitMq的情况,因此在同事的帮助下,成功实现了监听多个MQ。下面我给大家一步一步讲解下,也为自己做个笔记; 详细步骤: 1. application.properties 文件配置: u.rabbitmq.ad

leetcode刷题(41)——232. 用栈实现队列

使用栈实现队列的下列操作: push(x) – 将一个元素放入队列的尾部。 pop() – 从队列首部移除元素。 peek() – 返回队列首部的元素。 empty() – 返回队列是否为空。 示例: MyQueue queue = new MyQueue();queue.push(1);queue.push(2); queue.peek(); // 返回 1queue.pop();

【算法】优先级队列-基础与应用

优先级队列(Priority Queue)是一种特殊的队列类型,它允许在其元素中分配优先级。与传统的先进先出(FIFO)队列不同,优先级队列中元素的出队顺序取决于它们的优先级。优先级较高的元素会被优先处理,即使它们是在优先级较低的元素之后被加入队列的。 优先级队列的特点: 插入操作:新元素被添加到队列中时,它们根据自身的优先级被放置在适当的位置。移除操作:优先级队列通常移除并返回具有最高优先

Python 算法交易实验72 QTV200第一步: 获取原始数据并存入队列

说明 最近的数据流往前进了一步,我觉得基本可以开始同步的推进QTV200了。上次规划了整体的数据流,现在开始第一步。 内容 1 结构位置 这是上次的总体图: 以下是这次要实现的一小部分: 从结构上,这个是整体数据流的起点,系统因为这些不断 运行的数据才开始“动”了起来,可以称为源点。 2 规范与约束 源点是基于每分钟的节拍从外界读取数据,这部分目前我没用用付费接口(数据的需求量很

【Orange Pi 5与Linux编程编程】-POSIX消息队列

Linux系统中的POSIX消息队列编程 文章目录 Linux系统中的POSIX消息队列编程1、POSIX 消息队列2、Linux 中的 POSIX 消息队列命名3、POSIX 消息队列调用3.1 mq_open, mq_close3.2 mq_timed_send、mq_send、mq_timed_receive、mq_receive3.3 mq_notify3.4 mq_unlink3