SDUT2088refresh的停车场

本文介绍了一个使用C++实现的程序,该程序通过队列和栈来模拟一系列操作,包括添加元素(Add)、删除元素(Del)和移除队列首部元素(Out)。程序确保栈的大小不超过给定限制,并在必要时从队列中补充元素。
#include<bits/stdc++.h>
using namespace std;
int f(char z[5])
{
    if(strcmp(z,"Add")==0)
        return 0;
    else if(strcmp(z,"Del")==0)
        return 1;
    else if(strcmp(z,"Out")==0)
        return 2;
}
void refresh(int n,int m)
{
    queue<long long int>Q;
    stack<long long int>S;
    int flag=1;
    while(m--)
    {
        char a[5];
        scanf("%s",a);
        if(f(a)==0)///Add
        {
            long long int num;
            scanf("%lld",&num);
            if(S.size()<n)
                S.push(num);
            else
                Q.push(num);
        }
        else if(f(a)==1)///Del
        {
            if(S.empty())
                flag=0;
            else
            {
                S.pop();
                if(!Q.empty())
                {
                    long long int t=Q.front();
                    Q.pop();
                    S.push(t);
                }
            }
        }
        else if(f(a)==2)///Out
        {
            if(Q.empty())
                flag=0;
            else
                Q.pop();
        }
    }
    if(!flag)
        printf("Error\n");
    else
        while(!S.empty())
        {
            printf("%lld\n",S.top());
            S.pop();
        }
}
int main()
{
    int n,m;
    while(~scanf("%d%d",&n,&m))
        refresh(n,m);
}

初始化停车场(确定车区个数n,每个车区的停车位,且初始时,停车场为空),说明:使用一个共享数组(临界资源)存储每个车区中空闲停车位的个数,每一个车区使用一个共享缓冲区可容纳一辆车,停车场公共通道允许通过两辆车通过。 停车场入口检查是否有空闲位,如果有发放相关车区的车卡,允许车。如果不存在空闲车位,等待到有空闲车位止。注,入口处应尽量发放不同车区的车卡,以获得更高的效率。停车场过道允许两辆车同时通过。 停车场出口,回收车卡,并修改相关车区空闲车位数。注:同一时刻只能有一个车出停车场。 每一个车区,有一个待车位,供进入车区车辆进入车区。车区只能有一辆车进或出。 每辆车每进入下一环节皆应留一定时间。每一个用户建立一个窗口,于窗口中显示当前将态。将状态转换可由人工确定亦可自动完成,但进入下状态时需要留学生一定的时间,以保证多个用户“并行”工作。 本框架由四个类组成,这四个类分别是:InitFrame、WotkFram、carJFrame及carThread,由InitFrame启动。类InitFrame提供停车场初始化功能,完成初始任务后启动类WotkFram界面,执行停车场模拟程序,点击命令按扭“进入停车场”,建立一个线程(线程类名为carThread),线程建立一个carJFrame窗口(车辆进入、离开停车场操作程序)模拟车辆进入或离开停车场
### SDUT PTA 编程题解与在线评测系统使用说明 #### 关于SDUT PTA在线评测系统的概述 SDUT PTA(Programming Teaching Assistant)是一个面向学生学习编程的在线评测平台,主要用于支持山东理工大学计算机科学及相关专业的课程教学。该平台提供了丰富的练习题目以及自动化的测试机制,帮助学生巩固所学的知识并提升实际编程能力[^1]。 #### 如何使用SDUT PTA在线评测系统? 以下是关于如何有效利用SDUT PTA进行编程训练的关键要点: 1. **注册账号** 学生需通过学校指定的方式完成账户注册,并登录到对应的班级页面参与作业提交和考试活动。 2. **熟悉界面布局** 登录后可以看到左侧导航栏包含了“我的作业”、“公开试题”等功能模块;右侧则显示具体任务列表及其状态信息(未做/已交/得分情况)。点击某道题目可以查看其详细描述、样例输入输出以及其他提示内容[^2]。 3. **编写代码并调试** 对于像“计算1到n的和”的简单问题,可以直接采用如下C语言实现方式来解决: ```c #include<stdio.h> int main(){ int n, sum=0; scanf("%d",&n); for(int i=1;i<=n;i++) { sum +=i; } printf("%d\n",sum); return 0; } ``` 此段代码实现了基本的功能需求——读取用户输入的一个正整数值`n`,并通过循环累加得到最终的结果输出。 4. **提交解决方案** 完成本地开发环境中的编码工作之后,在网页端找到对应位置上传源文件或者直接粘贴文本框内的代码片段即可发起评测请求。注意遵循每道题目的特殊约束条件比如时间复杂度限制等规定。 5. **分析反馈结果** 提交完成后会迅速获得运行状况报告,如果存在错误,则应仔细阅读报错消息重新审视自己的逻辑是否存在漏洞再尝试修正直至完全正确为止。 #### 常见问题解答 对于初学者来说可能会遇到一些困惑之处,下面列举几个典型场景供参考: - 如果发现即使按照标准答案复制也得不到满分怎么办?可能是因为忽略了某些边界情形处理或者是格式化方面的小失误所致。 - 当面对较复杂的算法类挑战不知道从哪里下手时建议先梳理清楚思路画流程图辅助理解后再动手实践。 - 还有就是保持耐心多试几次不要轻易放弃因为每一次失败都是成长的机会! ###
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值