有一个字符串向量列表:
xx <- c("concord wanderer basic set air snug beige", "concord wanderer basic set air snug black noir", "concord wanderer basic set air snug blue bleu", "concord wanderer basic set air snug brown marron", "concord wanderer basic set air snug green vert", "concord wanderer basic set air snug grey gris", "concord wanderer basic set air snug red rouge", "concord wanderer basic set air snug rose" )
我试图在向量的元素之间获得最小的共享部分,例如,在这里我应该得到:
"concord wanderer basic set air snug"
xx是前一个过程的结果,所以我确信元素之间存在共享部分.但被删除的部分并不总是在他的结尾.
使用strsplit
和`table
我得到这个部分解决方案,但它有点棘手,我放松了原始的单词顺序:
table_x <- table(unlist(strsplit(xx,' '))) paste(names(table_x[table_x==max(table_x)]),collapse=' ') [1] "air basic concord set snug wanderer"
我很确定有更好的解决方案.我试着用agrep
或adist
但没有很多成功的.
您可以使用intersect
with Reduce
来获得所需的输出.
paste(Reduce(intersect, strsplit(xx, " ")), collapse=" ") #[1] "concord wanderer basic set air snug"