每次取相邻的两个可以射击的从序列中删除,重复n次。

可以看作括号序列的匹配。

#include<cstdio>
#include<vector>
using namespace std;
struct data
{
char c;
int p;
data(){}
data(const char &cc,const int &pp)
{
c=cc;
p=pp;
}
};
vector<data>a;
typedef vector<data>::iterator ITER;
int n,shoot[5010];
char s[10010];
int main()
{
//freopen("h.in","r",stdin);
int p1=0,p2=0;
scanf("%d%s",&n,s);
for(int i=0;i<n*2;++i)
{
if(s[i]>='A' && s[i]<='Z')
{
++p1;
a.push_back(data(s[i],p1));
}
else
{
++p2;
a.push_back(data(s[i],p2));
}
}
for(int i=0;i<n;++i)
{
bool flag=0;
ITER k=a.begin(); ++k;
for(ITER j=a.begin();k!=a.end();++j,++k)
if((*j).c==(*k).c-32)
{
shoot[(*j).p]=(*k).p;
++k;
a.erase(j,k);
flag=1;
break;
}
else if((*j).c-32==(*k).c)
{
shoot[(*k).p]=(*j).p;
++k;
a.erase(j,k);
flag=1;
break;
}
if(!flag)
{
puts("Impossible");
return 0;
}
}
for(int i=1;i<n;++i)
printf("%d ",shoot[i]);
printf("%d\n",shoot[n]);
return 0;
}

最新文章

  1. CSS3梅花三弄特效
  2. .添加索引和类型,同时设定edgengram分词和charsplit分词
  3. 监控redis python脚本
  4. JAVA中的类和接口
  5. HTML超标记语言
  6. nefu558 bfs
  7. Windows Store App 旋转特效
  8. MongoDB之bson的介绍
  9. 修复跨站攻击 php
  10. [html] Quirks Standards
  11. 第三百二十五天 how can I 坚持
  12. Laravel 清空配置缓存
  13. EF Code First学习笔记 初识Code First
  14. ognl表达式和s标签
  15. C —— 零碎笔记
  16. 在ASP.NET MVC 中获取当前URL、controller、action(转)
  17. Intellij IDEA编译代码出现红色标志
  18. 如何修改PDF文件内容,PDF怎么添加背景
  19. flume用场景及架构原理
  20. Could not load file or assembly &#39;Microsoft.ReportViewer.WebForms, Version=11.0.0.0, Culture=neutral, PublicKeyToken=89845dcd8080cc91&#39; or one of its dependencies

热门文章

  1. 2017福建省赛 FZU2272~2283
  2. springboot中 后端跨域的实现配置
  3. angular js module 的理解
  4. mysql的中文乱码问题
  5. 数学:Lucas定理
  6. vivo面试经验4(linux基本操作,最基本,必须得会!!)
  7. bzoj4602 [Sdoi2016]齿轮
  8. C# 文件类的操作---获取
  9. nginx中fastcgi_params配置参数
  10. urlparse获取url后面的参数