【贪心】Gym - 100507H - Pair: normal and paranormal
2024-09-19 14:48:03
每次取相邻的两个可以射击的从序列中删除,重复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;
}
最新文章
- CSS3梅花三弄特效
- .添加索引和类型,同时设定edgengram分词和charsplit分词
- 监控redis python脚本
- JAVA中的类和接口
- HTML超标记语言
- nefu558 bfs
- Windows Store App 旋转特效
- MongoDB之bson的介绍
- 修复跨站攻击 php
- [html] Quirks Standards
- 第三百二十五天 how can I 坚持
- Laravel 清空配置缓存
- EF Code First学习笔记 初识Code First
- ognl表达式和s标签
- C —— 零碎笔记
- 在ASP.NET MVC 中获取当前URL、controller、action(转)
- Intellij IDEA编译代码出现红色标志
- 如何修改PDF文件内容,PDF怎么添加背景
- flume用场景及架构原理
- 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