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
/*Sample code to read in test cases:*/
#include <iostream>
#include <fstream>
#include <string>
#include <sstream>
using namespace std;
int main()
{
int m, n, i;
int len;//当前播放记录长度
fstream file;
char sysInputFile[] = "{sysFileUrl}";
file.open(sysInputFile);
string lineBuffer, word;
while (!file.eof() && lineBuffer.length() == 0)
getline(file,lineBuffer);
istringstream line(lineBuffer);
line >> i;//数据组数
while (i-- != 0)
{
do
{
getline(file, lineBuffer);
}
while (!file.eof() && lineBuffer.length() == 0);
line.clear();
line.str(lineBuffer);
line >> n >> m;
int *list = new int[m]();//播放记录清单
list[0] = 1;//默认播放第一首歌
len = 1;//默认播放记录长度为1
while (!file.eof() && m != 0)
{
getline(file, lineBuffer);
if (lineBuffer.length() == 0)
continue; //ignore all empty lines
else
{
line.clear();
line.str(lineBuffer);
line >> word;
if (word == "PRE")
{
if (len != 1)
--len;
}
else if (word == "NEXT")
{
if (list[len - 1] == n)
list[len] = n;
else
list[len] = list[len - 1] + 1;
++len;
}
else if (word == "PLAY")
{
line >> list[len++];
}
if (list[len - 1] == list[len - 2])//如果添加进播放记录的歌曲与上一次重复,则删掉该次播放记录
{
--len;
}
cout << list[len - 1] << endl;
--m;
//do something here
}
}
delete []list;
}
return 0;
}