【CodeForces 730H】Delete Them
BUPT 2017 summer training (for 16) #1E
题意
找到匹配要删除的文件名们但不匹配其它文件名们的表达式。其中?匹配所有字符,其它字符匹配本身。
题解
如果某个位置出现两个及以上的不同字符,那就要用?。再看是否会匹配其它文件名。注意长度不同一定不匹配。
代码
#include <cstdio>
char w[101][101];
bool d[101];
char o[101];
int n,m;
int main(){
scanf("%d%d",&n,&m);
for(int i=1;i<=n;++i)
scanf("%s",w[i]);
for(int i=1,t;i<=m;++i)
scanf("%d",&t),d[t]=true;
bool ans=true;
int len=0;
for(int i=1,j;i<=n;++i)
if(d[i]){
for(j=0;w[i][j];++j)
if(o[j]&&o[j]!=w[i][j])
o[j]='?';
else
o[j]=w[i][j];
if(len==0)len=j;
if(j!=len)ans=false;
}
for(int i=1,j;i<=n&&ans;++i)
if(!d[i]){
bool dif=false;
for(j=0;w[i][j];++j)
if(o[j]!='?'&&w[i][j]!=o[j])
dif=true;
if(!dif&&j==len)ans=false;
}
if(ans)printf("Yes\n%s",o);
else puts("No");
return 0;
}
┆凉┆暖┆降┆等┆幸┆我┆我┆里┆将┆ ┆可┆有┆谦┆戮┆那┆ ┆大┆始┆ ┆然┆
┆薄┆一┆临┆你┆的┆还┆没┆ ┆来┆ ┆是┆来┆逊┆没┆些┆ ┆雁┆终┆ ┆而┆
┆ ┆暖┆ ┆如┆地┆站┆有┆ ┆也┆ ┆我┆ ┆的┆有┆精┆ ┆也┆没┆ ┆你┆
┆ ┆这┆ ┆试┆方┆在┆逃┆ ┆会┆ ┆在┆ ┆清┆来┆准┆ ┆没┆有┆ ┆没┆
┆ ┆生┆ ┆探┆ ┆最┆避┆ ┆在┆ ┆这┆ ┆晨┆ ┆的┆ ┆有┆来┆ ┆有┆
┆ ┆之┆ ┆般┆ ┆不┆ ┆ ┆这┆ ┆里┆ ┆没┆ ┆杀┆ ┆来┆ ┆ ┆来┆