从字典反推字符集顺序

给你一本字典,里面有一系列字符串,但是其中A,B,C,D...的大小关系不明确,是否能反推出这些字符的大小关系?

下面写了一点点想法,建立一个字符表表,里面代表着字符的次序,一开始全部初始化为0,然后由每一对相邻的字符串,可以得到至多一对字符的大小关系。

这里我只考虑,字典前后不出现自相矛盾的情况。

 

当遇到这样一对字符的时候,有4种情况:

a.两个字符都没有遇到过

那么赋值为1,2序号表示次序,同时与没有遇到的字符值0区分开

 

b.较小的字符第一次遇到,较大的字符有值

如果较大的字符值不是1的话,那么较小的字符值=较大的字符值-1

否则较小的字符值=1,其他所有已经有值的字符值全部加1

 

c.遇到较小的字符有值,序号较大的字符第一次遇到

那么序号较大的字符值=较小的字符的值+1除此之外不能得到其他有用信息

 

d.两者都有值

如果较小字符的值<较大字符值那么这一对字符串没有给我们带来什么有效信息,通过前面的字符串我们已经可以判断出来

如果较小字符的值>=较大字符值那么这是由于之前采用的保守策略导致的

处理方法如下:较小字符值=较大字符值,除了较小字符其他所有>=较大字符值的值全部+1

 

经过遍历一遍字典

我们可以得到一个字符值表,如果表中出现等值情况,说明字典所给信息不足以判断所有字符信息,否则应该可以确定

不知道是否考虑完整。

 

#include #include #include #include #include using namespace std; int seqence[26]={0}; void prase(char *p1,char *p2,int len1,int len2) { while(*p1==*p2&&len1>0&&len2>0) { p1++; p2++; len1--; len2--; } if(len1==0||len2==0) return; else { int pos1=*p1-'a'; int pos2=*p2-'a'; if(seqence[pos1]==0&&seqence[pos2]==0) { seqence[pos1]=1; seqence[pos2]=2; } else if(seqence[pos1]==0) { if(seqence[pos2]>1) seqence[pos1] = seqence[pos2]-1; else { seqence[pos1]=1; for(int j=0;j<26;j++) if(seqence[j]!=0&&j!=pos1) seqence[j]++; } } else if(seqence[pos2]==0) { seqence[pos2]=seqence[pos1]+1; } else { if(seqence[pos1]>seqence[pos2]) { seqence[pos1]=seqence[pos2]; for(int j=0;j<26;j++) if(seqence[j]>=seqence[pos2]&&j!=pos1) seqence[j]++; } } } } int main() { char dic[4][4]={"ab","ac","b","c"}; for(int i=0;i<2;i++) prase(dic[i],dic[i+1],strlen(dic[i]),strlen(dic[i+1])); for(int j=0;j<26;j++) cout << seqence[j] << " " ; return 0 ; }

你可能感兴趣的:(从字典反推字符集顺序)