R中是否有一个函数可以将向量中的第一个元素与最后一个元素进行切换?我有一个需要重新排序的 for 循环。从:
months = seq(1:12)
[1] 1 2 3 4 5 6 7 8 9 10 11 12
我想拥有:
[1] 12 1 2 3 4 5 6 7 8 9 10 11
然后再一次:
[1] 11 12 1 2 3 4 5 6 7 8 9 10
...直到第 12 位。
R中是否有一个函数可以将向量中的第一个元素与最后一个元素进行切换?我有一个需要重新排序的 for 循环。从:
months = seq(1:12)
[1] 1 2 3 4 5 6 7 8 9 10 11 12
我想拥有:
[1] 12 1 2 3 4 5 6 7 8 9 10 11
然后再一次:
[1] 11 12 1 2 3 4 5 6 7 8 9 10
...直到第 12 位。
如果您需要矩阵输出
cbind(c(months),embed(c(months, months), 12)[-13,-12])
# [,1] [,2] [,3] [,4] [,5] [,6] [,7] [,8] [,9] [,10] [,11] [,12]
# [1,] 1 12 11 10 9 8 7 6 5 4 3 2
# [2,] 2 1 12 11 10 9 8 7 6 5 4 3
# [3,] 3 2 1 12 11 10 9 8 7 6 5 4
# [4,] 4 3 2 1 12 11 10 9 8 7 6 5
# [5,] 5 4 3 2 1 12 11 10 9 8 7 6
# [6,] 6 5 4 3 2 1 12 11 10 9 8 7
# [7,] 7 6 5 4 3 2 1 12 11 10 9 8
# [8,] 8 7 6 5 4 3 2 1 12 11 10 9
# [9,] 9 8 7 6 5 4 3 2 1 12 11 10
#[10,] 10 9 8 7 6 5 4 3 2 1 12 11
#[11,] 11 10 9 8 7 6 5 4 3 2 1 12
#[12,] 12 11 10 9 8 7 6 5 4 3 2 1
或者@Marat Talipov 建议的另一个方法
z <- length(months)
i <- rep(seq(z),z) + rep(seq(z),each=z) - 1
matrix(months[ifelse(i>z,i-z,i)],ncol=z)
恐怕你必须想出一个自制的功能,像这样:
rotate <- function(v,i=1) {
i <- i %% length(v)
if (i==0) return(v)
v[c(seq(i+1,length(v)),seq(i))]
}
几个例子:
v <- seq(12)
rotate(v,1)
# [1] 2 3 4 5 6 7 8 9 10 11 12 1
rotate(v,-1)
# [1] 12 1 2 3 4 5 6 7 8 9 10 11
permute包可以为您执行此操作:
ap <- allPerms(length(months),
control = how(within = Within(type = "series"),
observed = TRUE))
ap[rev(seq_len(nrow(ap))), ]
(因为allPerms()
它的工作方式,我们需要颠倒行的顺序,这就是最后一行所做的。)
这给出了:
> ap[rev(seq_len(nrow(ap))), ]
[,1] [,2] [,3] [,4] [,5] [,6] [,7] [,8] [,9] [,10] [,11] [,12]
[1,] 1 2 3 4 5 6 7 8 9 10 11 12
[2,] 12 1 2 3 4 5 6 7 8 9 10 11
[3,] 11 12 1 2 3 4 5 6 7 8 9 10
[4,] 10 11 12 1 2 3 4 5 6 7 8 9
[5,] 9 10 11 12 1 2 3 4 5 6 7 8
[6,] 8 9 10 11 12 1 2 3 4 5 6 7
[7,] 7 8 9 10 11 12 1 2 3 4 5 6
[8,] 6 7 8 9 10 11 12 1 2 3 4 5
[9,] 5 6 7 8 9 10 11 12 1 2 3 4
[10,] 4 5 6 7 8 9 10 11 12 1 2 3
[11,] 3 4 5 6 7 8 9 10 11 12 1 2
[12,] 2 3 4 5 6 7 8 9 10 11 12 1
从技术上讲,这仅有效,因为months
它是向量1:12
并allPerms()
返回您想要置换的事物的索引的置换矩阵。对于不同的输入,用于ap
索引到您想要置换的内容
perms <- ap
perms[] <- months[ap[rev(seq_len(nrow(ap))), ]]
perms
您还可以使用tail
和head
功能:
x = c(tail(x,n), head(x,-n))
并修改n
为轮换n
时间