小明放学

CCF真题

#include<iostream>
#include<vector>
#include<string>
#include<set>
#include<map>
#include<algorithm>
using namespace std;
int r,y,g;
int judge(long long int time)
{
    if(0<=time&&time<r)return 1;
    if(r+g<=time&&time<r+g+y)return 2;
    if(r<=time&&time<r+g)return 3;
}
int main()
{
    int n;
    cin>>r>>y>>g;
    cin>>n;
    long long int ans=0;
    for(int i=0;i<n;i++)
    {
        int k,t;
        cin>>k>>t;
        switch(k)
        {
            case 0://道路直接走
            {
                ans=ans+t;
                break;
            }
            case 1://红灯
            {
                long long int tt=r-t;
                tt=(tt+ans)%(r+y+g);
                int f=judge(tt);
                if(f==1)//红灯
                    ans=ans+r-tt;
                else if(f==2)//黄灯
                    ans=ans+r+y+g-tt+r;
                break;
            }
            case 2:
            {
                long long int tt=r+g+y-t;
                tt=(tt+ans)%(r+y+g);
                int f=judge(tt);
                if(f==1)//红灯
                    ans=ans+r-tt;
                else if(f==2)//黄灯
                    ans=ans+r+y+g-tt+r;
                break;
            }
            case 3:
            {
                long long int tt=r+g-t;
                tt=(tt+ans)%(r+y+g);
                int f=judge(tt);
                if(f==1)//红灯
                    ans=ans+r-tt;
                else if(f==2)//黄灯
                    ans=ans+r+y+g-tt+r;
                break;
            }
        }
    }
    cout<<ans<<endl;
    return 0;
}

1.注意本题的输入的是小明放学开始走时的红绿灯以及显示的时间

2.显示的时间是剩余时间,比如红灯显示25,那么真正经过的时间是r-25,如果小明从开始到当前红灯花了50秒,那么红灯经过的时间是55秒(r假设为30)这种操作目的是为了以红灯为起点来计算时间,最终取模r+y+g来判断当前灯的情况,这里灯的顺序拟定为红-绿-黄。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值