您的位置:首页 > 其它

fzu 2091 播放器(字符串栈模拟)

2016-04-13 22:48 633 查看
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

1

5 10

PRE

NEXT

PLAY 5

NEXT

PLAY 5

PLAY 3

NEXT

PRE

PRE

PRE

Sample Output

1

2

5

5

5

3

4

3

5

2

用数组模拟栈,当然你也可以用stack容器。那个一样的。

也没什么好讲了。。。题目白底黑字都写着。

#include<iostream>
#include<string>
#include<cstring>
using namespace std;
int x[10000+500+10];
int main()
{
ios::sync_with_stdio(false);
int t;
cin>>t;
while(t--)
{
memset(x,0,sizeof(x));
int m,n;
cin>>n>>m;
x[1]=1;
int dp=1;
int *mw=&x[1];
while(m--)
{
string c;
cin>>c;
if(c=="PRE")
{
if(mw!=&x[1])
{
*mw=0;
mw--;
dp=*mw;
}
else dp=1;
}
else if(c=="PLAY")
{
int q;
cin>>q;
dp=q;
}
else if(c=="NEXT")
{
if(dp!=n)
{
dp++;
}
}
if(dp!=*mw)
{
mw++;
*mw=dp;
}
cout<<dp<<endl;
}
}
}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  ACM 字符串 模拟