播放器
来源:互联网 发布:阿里云网站上线教程 编辑:程序博客网 时间:2024/04/26 11:41
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
Sample Input
15 10PRENEXTPLAY 5NEXTPLAY 5PLAY 3NEXTPREPREPRE
Sample Output
1255534352
#include <iostream>
#include <string>
using namespace std;
int n,m,a[50010];
int main()
{ int T,i,t;
cin>>T;
while(T--)
{
cin>>n>>m;
string c;
int k=1,p=1;a[1]=1;
for(i=2;i<=n;i++)
a[i]=-1;
while(m--)
{
int q;
cin>>c;
if(c=="PRE")
{
k--;
if(k<1) k=1;
p=a[k];
cout<<a[k]<<endl;
}
else if(c=="NEXT")
{
k++;
if(p!=n)
a[k]=p+1;
else
{k--;
a[k]=p;}
p=a[k];
cout<<a[k]<<endl;
}
else if(c=="PLAY")
{
k++;
cin>>q;
if(q==a[k-1]) k--;
a[k]=q;
p=a[k];
cout<<a[k]<<endl;
}
}
}
return 0;
}
- 播放器
- 播放器
- 播放器
- 播放器
- 播放器
- 播放器
- 播放器
- 播放器
- 播放器
- - 播放器
- 播放器
- 播放器
- 播放器
- 播放器
- 播放器
- Web播放器flash播放器Flowplayer免费播放器
- 阿飞播放器 android 万能播放器
- 音乐播放器(5)-播放器架构
- 线程并发工具--Lock&Condition
- 走进C的世界-那些年我们常犯的错---关键字相关
- MySQL-Front 出现“程序注册时间到期 程序将被限制模式下运行”解决方式
- 数字签名,数字证书
- C++使用类的基本知识
- 播放器
- Hduoj2065 【数学】【水题】
- Python版图的深度/广度搜索
- c6x binutils 的构建方法
- NOI 2008 志愿者招募
- UDP与TCP的比较
- (最新)移动App应用安全漏洞分析报告 !
- 转 举办编程大赛,火热开启…
- VAR模型