F - 播放器

来源:互联网 发布:windows缩小图片大小 编辑:程序博客网 时间:2024/06/07 16:58
F - 播放器
Time Limit:1000MS     Memory Limit:32768KB     64bit IO Format:%I64d & %I64u
Submit Status Practice FZU 2091

Description

shadow喜欢听音乐,于是v11自己写了个播放器送给了shadow,这个播放器有一个播放列表,一个“下一首”按钮,一个“上一首”按钮,还有一个播放记录。

一开始播放器会播放播放列表中的第一首歌,当按下“下一首”按钮时,它会播放当前歌曲在播放列表中的下一首歌,若当前歌曲就是播放列表中的最后一首歌时,它仍会播放播放列表中的最后一首歌;当按下“上一首”按钮时,它会清除播放记录中的最后一首歌,并播放清除后播放记录中的最后一首歌,若清除后播放记录为空,则播放播放列表中的第一首歌;当按下播放列表中的某一首歌曲,它会播放该首歌曲。

任何时候,当播放器播放一首歌时,如果该歌曲与播放记录中的最后一首不同或者播放记录为空,便将该歌曲添加到播放记录中成为最后一首。

现在shadow对播放器进行了一系列操作,那么你能告诉我shadow进行每一个操作后,播放器在播放哪首歌吗?

Input

输入数据第一行包含一个整数T,表示测试数据的组数。对于每组测试数据:

第一行包含两个整数n( 0 < n <= 500 )、m( 0 < m <= 10000),分别表示播放列表中有n首歌曲,shadow进行了m项操作,播放列表中歌的编号依次为1,2,3……n 。

接下来m行,每行为以下三种形式之一:

PRE 表示按下了“上一首”按钮。

PLAY x 其中x为一个整数( 0 < x <= n ),表示按下了播放列表中的第x首歌。

NEXT 表示按下了“下一首”按钮。

Output

对于每组数据:输出m行,每行一个整数,表示执行了一项操作后播放器正在播放的歌曲。

Sample Input

15 10PRENEXTPLAY 5NEXTPLAY 5PLAY 3NEXTPREPREPRE

Sample Output

1255534352




#include <iostream>#include<stdio.h>#include<string>#include<algorithm>#include<cmath>#include<algorithm>#include<iostream>#include<cstring>#include <stdlib.h>using namespace std;int main(){    int t,l,m,n,i,j,k,a[10000];    string str;    cin>>t;    while(t--)    {        k=0;        a[k]=1;        cin>>n>>m;        for(i=0;i<m;i++)        {            cin>>str;            k++;            if(str=="NEXT")        {            if(a[k-1]==n){cout<<a[k-1]<<endl;a[k]=a[k-1];if(a[k]==a[k-1]){a[k]=0;k--;}}            else {a[k]=a[k-1]+1;cout<<a[k]<<endl;}        }            if(str=="PRE")            {                a[k-1]=0;                if((k-1)==0){k=0;a[k]=1;cout<<a[k]<<endl;}                else {cout<<a[k-2]<<endl;k-=2;}            }            if(str=="PLAY")            {                cin>>l;                cout<<l<<endl;a[k]=l;if(a[k]==a[k-1]){a[k]=0;k--;}            }            str[0]=0;    }    }    return 0;}


0 0
原创粉丝点击