作者热门文章
- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
给定一个向量,例如:
labels <- c(1,2,3,3,3)
如何获得所有可能的组重新标记?对于这个例子:
1,2,3,3,3
1,3,2,2,2
2,1,3,3,3
2,3,1,1,1
3,1,2,2,2
3,2,1,1,1
我一直在查看 permute
包,但我不知道如何将其应用到这种情况。
最佳答案
这个解决方案怎么样
labels <- c(1,2,3,3,3)
library(data.table)
a <- do.call(cbind, combinat::permn(unique(labels)))
data.table(a)[,lapply(.SD, function(x)x[labels]),]
# V1 V2 V3 V4 V5 V6
#1: 1 1 3 3 2 2
#2: 2 3 1 2 3 1
#3: 3 2 2 1 1 3
#4: 3 2 2 1 1 3
#5: 3 2 2 1 1 3
或者,只是
apply(a, 2, function(x) x[labels])
# [,1] [,2] [,3] [,4] [,5] [,6]
#[1,] 1 1 3 3 2 2
#[2,] 2 3 1 2 3 1
#[3,] 3 2 2 1 1 3
#[4,] 3 2 2 1 1 3
#[5,] 3 2 2 1 1 3
关于r - 如何用R计算组标签的排列?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29653503/
我是一名优秀的程序员,十分优秀!