L2-037 包装机 (25 分)

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

直接上代码

#include<bits/stdc++.h>
#include<queue>
#include<stack>
using namespace std;
int main() {
	int n,m,s,i,j;
	queue <char> a[101];
	cin>>n>>m>>s;
	char ch;
	for(i=0; i<n; i++) {
		for(j=0; j<m; j++) {
			cin>>ch;
			a[i].push(ch);
		}
	}
	int b;
	stack <char> c1;
	queue <char> c2;
	while(cin>>b) {
		if(b==-1) {
			break;
		}
		if(b!=0) {
			if(a[b-1].size()>0) {
				if(c1.size()>=s) {
					c2.push(c1.top());
					c1.pop();
				}

				c1.push(a[b-1].front());
				a[b-1].pop();
			}

		} else {
			if(c1.size()>0) {
				c2.push(c1.top());
				c1.pop();
			}
		}
	}
	int size=c2.size();
	for(i=0; i<size; i++) {
		cout<<c2.front();
		c2.pop();
	}
}

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值