P2952 [USACO09OPEN] Cow Line S

题目描述

Farmer John's N cows (conveniently numbered 1..N) are forming a line. The line begins with no cows and then, as time progresses, one by one, the cows join the line on the left or right side. Every once in a while, some number of cows on the left or right side of the line all leave the line to go graze in their favorite pasture.

FJ has trouble keeping track of all the cows in the line. Please help him.

The cows enter the line in numerical order 1..N, and once a cow leaves the line she never re-enters it. Your program will be given S (1 <= S <= 100,000) input specifications; each appears on a single line and is one of two types:

* A cow enters the line (a parameter indicates whether on the left or right).

* K cows leave the line from the left or right side (supplied parameters define both the number of cows and which side).

Input lines never request an operation that can not be performed.

After all the input lines have been processed, your program should print the cows in the line in order from left to right. The final line is guaranteed to be non-empty at the end of the input specifications.

输入格式

* Line 1: A single integer: S

* Lines 2..S+1: Line i+1 contains specification i in one of four formats:

* A L -- a cow arrives on the Left of the line

* A R -- a cow arrives on the Right of the line

* D L K -- K cows depart the Left side of the line

* D R K -- K cows depart the Right side of the line

输出格式

* Lines 1..n: Print the numbers of the cows in the line in order from left to right, one number per line.

题意翻译

Farmer John(以下简称 FJ)的 N 头奶牛(用 1…N 编号)在直线上排队。一开始,这条线上没有任何奶牛,随着时间的推移,奶牛们会一个接一个地站到队伍的左边或右边。又过了一会儿,某些奶牛会从队伍里离开,去吃自己最喜欢的草料。

FJ 无法跟踪每一头奶牛,于是,他想让你来帮助他。

奶牛以 1…N 的顺序排队,并且离开的奶牛不会再次回来。数据将会给出 S(1≤S≤100000) 条指令,各占一行,分两种:

  • A 头奶牛加入了队列(还有一个参数,表示从左加入还是从右加入);
  • K 头奶牛从左边或者右边离开了队列(还有两个参数,分别表示从左离开还是从右离开和离开多少头奶牛)。

输入的命令一定是可以执行的。

所有的操作结束后,你的程序应该以从左到右的顺序输出这个奶牛队列。数据保证最后的队列不空。

【输入格式】

  • 第 11 行:单独一个整数 S。
  • 第 2…S+1 行;每行会有一条命令,有以下几种:
    • A L:一头奶牛从队列左边加入;
    • A R:一头奶牛从队列右边加入;
    • D L K:K 头奶牛从队伍左边离开;
    • D R K:K 头奶牛从队伍右边离开。

【输出格式】

  • 第 1… 行:从左到右输出最后的奶牛队列,一个奶牛编号占一行。

#include<bits/stdc++.h>
using namespace std;
int main(){int s;cin>>s;deque<int>ans;int now=1;while(s--){char a;cin>>a;if(a=='A'){cin>>a;if(a=='L'){ans.push_front(now);now++;}if(a=='R'){ans.push_back(now);now++;}}if(a=='D'){cin>>a;if(a=='L'){int x;cin>>x;while(x--)ans.pop_front();}if(a=='R'){int x;cin>>x;while(x--)ans.pop_back();}}}for(int i=0;i<ans.size();i++)cout<<ans[i]<<"\n";
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/679844.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

LeetCode 0094.二叉树的中序遍历:递归/迭代(栈模拟递归)

【LetMeFly】94.二叉树的中序遍历&#xff1a;递归/迭代(栈模拟递归) 力扣题目链接&#xff1a;https://leetcode.cn/problems/binary-tree-inorder-traversal/ 给定一个二叉树的根节点 root &#xff0c;返回 它的 中序 遍历 。 示例 1&#xff1a; 输入&#xff1a;root […

操作系统——内存管理(附带Leetcode算法题LRU)

目录 1.内存管理主要用来干什么&#xff1f; 2.什么是内存碎片&#xff1f; 3.虚拟内存 3.1传统存储管理方式的缺点&#xff1f; 3.2局部性原理 3.3什么是虚拟内存&#xff1f;有什么用&#xff1f; 3.3.1段式分配 3.3.2页式分配 3.3.2.1换页机制 3.3.2.2页面置换算法…

SSM实现支付宝沙盒支付

文章目录 沙盒支付准备配置测试 沙盒支付 这里用的支付宝的一个沙盒环境&#xff0c;是支付宝提供给开发者测试用的。 下面主要梳理一下&#xff0c;支付功能的实现&#xff0c;其实还是很简单的&#xff0c;因为支付宝都提供好了&#xff0c;我们只要调用接口去传入参数即可…

C# EventHandler<T> 示例

新建一个form程序&#xff0c;在调试窗口输出执行过程&#xff1b; 为了使用Debug.WriteLine&#xff0c;添加 using System.Diagnostics; using System; using System.Collections.Generic; using System.ComponentModel; using System.Data; using System.Drawing; using S…

写的太通透了!大模型自省式 RAG 与 LangGraph 的实践!

本文讲解了自省式 RAG 的基础原理以及基于 LangGraph 的实践演示 自省式 RAG 与 LangGraph 重要链接 关于 Self-RAG 和 CRAG 的教程手册 演示视频 研究背景 由于大多数大型语言模型&#xff08;LLMs&#xff09;通常只针对大量公共数据进行周期性训练&#xff0c;它们往往…

使用python绘制无边框ECG信号-可用于论文插图-小白版

用python绘制一个心电信号 最近在写大论文&#xff0c;由于自己做的是心电信号难免要做一些心电信号的插图&#xff0c;然后在写论文的时候有的时候要用真实信号有的时候需要用到示意图&#xff0c;这里面的其他部分使用Visio绘制的&#xff0c;但是前面的心电信号部分&#x…

视觉slam十四讲学习笔记(三)李群与李代数

1. 理解李群与李代数的概念&#xff0c;掌握 SO(3), SE(3) 与对应李代数的表示方式。 2. 理解 BCH 近似的意义。 3. 学会在李代数上的扰动模型。 4. 使用 Sophus 对李代数进行运算。 目录 前言 一、李群李代数基础 1 群 2 李代数的引出 3 李代数的定义 4 李代数 so(3…

HAproxy+Mycat集群+MySQL主从组成高可用性方案架构图

如果还担心 HAproxy 的稳定性和单点问题&#xff0c;则可以用 keepalived 的 VIP 的浮动功能&#xff0c;加以强化&#xff1a;https://blog.csdn.net/gaofenglxx/article/details/118883060

如何在项目初始化时就将数据字典中的数据加载到Redis中

要在项目初始化时将数据字典中的数据加载到Redis中&#xff0c;可以按照以下步骤进行操作&#xff1a; 引入Redis依赖&#xff1a; 在项目的构建文件&#xff08;比如pom.xml&#xff09;中添加Redis相关的依赖项&#xff0c;以便能够使用Redis客户端。 连接Redis服务器&#…

re:从0开始的CSS之旅 12. 轮廓、阴影、圆角

1. 轮廓 outline 设置元素的轮廓 使用方式与border一样。不同在于不影响盒子的大小 2. 阴影 box-shadow 设置元素的阴影 box-shadow: 30px 30px 50px 5px rgba(0, 0, 0, .5); 第一个值&#xff1a;设置阴影水平距离 第二个值&#xff1a;设置阴影垂直距离 第三个值&#xff…

推荐在线图像处理程序源码

对于喜爱图像编辑的朋友们来说&#xff0c;Photoshop无疑是处理照片的利器。然而&#xff0c;传统的Photoshop软件不仅需要下载安装&#xff0c;还对电脑配置有一定的要求&#xff0c;这无疑增加了使用的门槛。 现在&#xff0c;我们为您带来一款革命性的在线PS修图工具——基…

探索嵌入式系统的未来发展趋势

嵌入式系统是一种专门设计用于特定应用领域的计算机系统&#xff0c;它通常被嵌入到更大的设备中&#xff0c;以执行特定的任务。随着科技的不断发展&#xff0c;嵌入式系统的未来发展趋势将受到多方面的影响&#xff0c;包括技术进步、市场需求和应用场景的拓展等。以下将从多…

LeetCode每日一题——993. Cousins in Binary Tree

文章目录 一、题目二、题解 一、题目 Given the root of a binary tree with unique values and the values of two different nodes of the tree x and y, return true if the nodes corresponding to the values x and y in the tree are cousins, or false otherwise. Two…

交易中的胜率和盈亏比估算

交易中的胜率和盈亏比估算 1.定义 胜率是指交易者在一定时间内成功交易的次数占总交易次数的比例。例如&#xff0c;如果交易者在10次交易中成功了6次&#xff0c;那么他的胜率就是60%。 盈亏比是指交易者每笔成功交易的盈利与每笔失败交易的亏损之间的比例。例如&#xff0…

泽攸科技ZEM系列台扫助力环境科研创新:可见光催化抗生素降解的探索

环境污染和能源短缺是当今人类社会面临的最严重威胁之一。为了克服这些问题&#xff0c;特别是在污水处理过程中&#xff0c;寻找新的技术来实现清洁、高效、经济的发展显得尤为重要。在各种工业废水中&#xff0c;抗生素的过量排放引起了广泛关注。抗生素的残留会污染土壤、水…

深入探索Flex布局:从基础到实战,附带抖音解决方案案例分析

文章目录 简介盒子模型概念版心居中 Flex布局组成主轴对齐方式侧轴对齐方式修改主轴方向弹性伸缩比弹性盒子换行行对齐方式案例-抖音解决方案效果图案例分析参考代码 领取完整源码 简介 在阅读本文之前&#xff0c;请确保你已经掌握CSS基本语法、常用属性以及CSS选择器。 盒模…

itext中通过freemark生成的pdf时,居中样式text-align: center没有效果

itext不支持css3的语法&#xff0c;结果css2的部分语法也可能不支持&#xff0c;比如text-align: center&#xff0c;一直没有效果&#xff0c;后来想到用table的方式 原始的代码&#xff1a; css 的 container中添加 text-align: center; <div class"container&quo…

12.08 校招 实习 内推 面经

绿*泡*泡VX&#xff1a; neituijunsir 交流裙 &#xff0c;内推/实习/校招汇总表格 1、校招&#xff5c;极智嘉2024届秋招补录全面开启&#xff08;内推&#xff09; 校招&#xff5c;极智嘉2024届秋招补录全面开启&#xff08;内推&#xff09; 2、校招&#xff5c;零跑汽…

【力扣每日一题】力扣144二叉树的前序遍历

题目来源 力扣144二叉树的前序遍历 题目概述 给你二叉树的根节点 root &#xff0c;返回它节点值的 前序 遍历。 思路分析 二叉树的前序遍历可以使用递归或迭代方式实现。 代码实现 java实现 java使用递归实现 public class Solution {List<Integer> res new A…