题意
给你某个字符串的长度n,再给你2*n-2个前缀或者后缀
让你判断那些是前缀那些是后缀
关键是1到n-1的都有两个
分析
只需分析长度为n-1的那两个谁是前缀,谁是后缀
#include<bits/stdc++.h>
using namespace std;
string s[210];
bool vis[110];
int main(){
int n;
//ios::sync_with_stdio(false); cin.tie(0); cout.tie(0);
//freopen("in.txt","r",stdin);
while(~scanf("%d",&n)){
bool flag=0;
string s1="a",s2="b",pre;
for(int i=0;i<2*n-2;i++)
{
cin>>s[i];
if(s[i].size()==n-1&&!flag){
s1=s[i]; flag=1;
}
else if(s[i].size()==n-1) s2=s[i];
}
int cnt=0;
for(int i=0;i<2*n-2;i++)
if(s1.substr(0,s[i].size())==s[i]&&s[i]!=s2) cnt++;
//若前缀超过n-1,且s1的最长后缀等于s2的最长前缀,说明s1是前缀
if(cnt>=n-1&&s1.substr(1,s1.size()-1)==s2.substr(0,s2.size()-1))
pre=s1;
else pre=s2;//否则s2为前缀
memset(vis,0,sizeof(vis));//标记相同长度的是否已经是前缀
for(int i=0;i<2*n-2;i++)
if(s[i]==pre.substr(0,s[i].size())&&!vis[s[i].size()]) {
printf("P"); vis[s[i].size()]=1;
}
else printf("S");
puts("");
}
return 0;
}
题意
给出长度为n的字符串的所有前缀和后缀,判断哪些是前缀哪些是后缀。
分析
找出长度为n-1的两个串,一个作为前缀一个作为后缀,就可以拼凑出一个完整的串,从拼出的串中拆出所有前缀和后缀存入multiset中,逐个判断给出的串是否存在集合中。若有不存在的就把最开始n-1的串前后缀反一下。
#include<stdio.h>
#include<algorithm>
#include<iostream>
#include<string.h>
#include<vector>
#include<stdlib.h>
#include<math.h>
#include<queue>
#include<deque>
#include<ctype.h>
#include<map>
#include<set>
#include<stack>
#include<string>
#define INF 0x3f3f3f3f
#define FAST_IO ios::sync_with_stdio(false)
const double PI = acos(-1.0);
const double eps = 1e-6;
const int MAX=1e5+10;
const int mod=1e9+7;
typedef long long ll;
using namespace std;
#define gcd(a,b) __gcd(a,b)
inline ll lcm(ll a,ll b){return a/gcd(a,b)*b;}
inline ll qpow(ll a,ll b){ll r=1,t=a; while(b){if(b&1)r=(r*t)%mod;b>>=1;t=(t*t)%mod;}return r;}
inline ll inv1(ll b){return qpow(b,mod-2);}
inline ll exgcd(ll a,ll b,ll &x,ll &y){if(!b){x=1;y=0;return a;}ll r=exgcd(b,a%b,y,x);y-=(a/b)*x;return r;}
inline ll read(){ll x=0,f=1;char c=getchar();for(;!isdigit(c);c=getchar()) if(c=='-') f=-1;for(;isdigit(c);c=getchar()) x=x*10+c-'0';return x*f;}
//freopen( "in.txt" , "r" , stdin );
//freopen( "data.txt" , "w" , stdout );
int n;
vector<string>v,s;
string ans;
int judge(string pre,string suf)
{
string yuan=pre+suf.substr(n-2);
//cout<<yuan<<"\n";
multiset<string> tpre,tsuf,vv;
for(int i=0;i<n-1;i++)
{
tsuf.insert(yuan.substr(i+1));
vv.insert(yuan.substr(i+1));
tpre.insert(yuan.substr(0,n-i-1));
vv.insert(yuan.substr(0,n-i-1));
}
if(vv == multiset<string>(v.begin(),v.end()))
{
for(int i=0;i<2*n-2;i++)
{
if(tpre.count(v[i]))
{
ans+='P';
tpre.erase(tpre.find(v[i]));
}
else if(tsuf.count(v[i]))
{
ans+='S';
tsuf.erase(tsuf.find(v[i]));
}
else
return 0;
}
return 1;
}
return 0;
}
int main()
{
scanf("%d",&n);
v = vector<string>(2 * n - 2);
for(int i=0;i<2*n-2;i++)
{
cin>>v[i];
if(v[i].size()==n-1)
{
//cout<<"--"<<t<<"--"<<endl;
s.push_back(v[i]);
}
}
//cout<<s[0]<<' '<<s[1]<<"\n";
if(judge(s[0],s[1]))
cout<<ans;
else
{
judge(s[1],s[0]);
cout<<ans;
}
return 0;
}