题解 | #MP3光标位置#

MP3光标位置

https://www.nowcoder.com/practice/eaf5b886bd6645dd9cfb5406f3753e15

#include <array>
#include <deque>
#include <iostream>
#include <vector>
using namespace std;

int main() {
    int n;
    string order;
    cin>>n>>order;
    deque<int>deq;
    vector<int>arr(n+1,0);

    for(int i=1;i<=4&&i<=n;++i)
    {
        deq.push_back(i);
        arr[i]=1;
    }
    int pos=0;
    for(int i=0;i<order.size();++i)
    {
        if(order[i]=='U')
        {
            pos=(pos-1+n)%n;
            if(pos==n-1&&n>4)
            {
                deq.clear();
                fill(arr.begin(),arr.end(),0);
                for(int i=0;i<4;++i)
                {
                    deq.push_front(n-i);
                    arr[n-i]=1;
                }
            }
            else if(arr[pos+1]!=1&&n>4)
            {
                arr[pos+1]=1;
                arr[deq.back()]=0;
                deq.pop_back();
                deq.push_front(pos+1);
            }
        }
        else {
            pos=(pos+1)%n;
            if(pos==0&&n>4)
            {
                deq.clear();
                fill(arr.begin(),arr.end(),0);
                for(int i=0;i<4;++i)
                {
                    deq.push_back(i+1);
                    arr[i+1]=1;
                }
            }
            else if(arr[pos+1]!=1&&n>4)
            {
                arr[pos+1]=1;
                arr[deq.front()]=0;
                deq.pop_front();
                deq.push_back(pos+1);           
            }
            
        }
    }
    for(auto i:deq)cout<<i<<" ";
    cout<<endl;
    cout<<pos+1<<endl;
}
// 64 位输出请用 printf("%lld")

deque(4) 用来存菜单,注意push 时的方向

下标 (pos+1)%n、(pos-1+n)%n

特殊情况:n<=4 ,不需要更新 deque

front---------

1----

2-----

3-----

4------

back-----------------

全部评论

相关推荐

程序员牛肉:主要是因为小厂的资金本来就很吃紧,所以更喜欢有实习经历的同学。来了就能上手。 而大厂因为钱多,实习生一天三四百的就不算事。所以愿意培养你,在面试的时候也就不在乎你有没有实习(除非是同级别大厂的实习。) 按照你的简历来看,同质化太严重了。项目也很烂大街。 要么换项目,要么考研。 你现在选择工作的话,前景不是很好了。
点赞 评论 收藏
分享
AAA专业长城贴瓷砖刘大爷:这样的简历我会直接丢进垃圾桶,花里胡哨的
点赞 评论 收藏
分享
存一千万就可以进大厂实习
石圪节公社发型师:有存一千万的实力还实习个嘚,直接躺平
点赞 评论 收藏
分享
评论
1
收藏
分享

创作者周榜

更多
牛客网
牛客企业服务