R,将数字输入转换为受上限限制的循环数字输出的函数
R, function that turns numeric input into a recycled numeric output bounded by a upper limit
我如何编写一个函数 f(v, n)
(或使用基本 R 函数)将一个数值向量 v
转换为另一个基于 n
、循环因子(缺少一个更好的词)。
例如:
f(v = c(1,2,3,4,5), n = 1) #would yield c(1,2,3,4,5)
f(v = c(1,2,3,4,5), n = 2) #would yield c(1,2,1,2,1)
f(v = c(1,2,3,4,5), n = 3) #would yield c(1,2,3,1,2)
f(v = c(5,4,3,2,1), n = 3) #would yield c(2,1,3,2,1)
f(v = c(3,6), n = 3) #would yield c(3,3)
我最接近的是使用 %%
1:5%%3 #giving me: [1] 1 2 0 1 2 - not quite what I want, at least some recycling.
我们可以将函数创建为
f <- function(x, n) if(n ==1) x else (x - 1) %% n + 1
f(1:5, 1)
#[1] 1 2 3 4 5
f(1:5, 2)
#[1] 1 2 1 2 1
f(1:5, 3)
#[1] 1 2 3 1 2
f(5:1, 3)
#[1] 2 1 3 2 1
f(c(3, 6), 3)
#[1] 3 3
我如何编写一个函数 f(v, n)
(或使用基本 R 函数)将一个数值向量 v
转换为另一个基于 n
、循环因子(缺少一个更好的词)。
例如:
f(v = c(1,2,3,4,5), n = 1) #would yield c(1,2,3,4,5)
f(v = c(1,2,3,4,5), n = 2) #would yield c(1,2,1,2,1)
f(v = c(1,2,3,4,5), n = 3) #would yield c(1,2,3,1,2)
f(v = c(5,4,3,2,1), n = 3) #would yield c(2,1,3,2,1)
f(v = c(3,6), n = 3) #would yield c(3,3)
我最接近的是使用 %%
1:5%%3 #giving me: [1] 1 2 0 1 2 - not quite what I want, at least some recycling.
我们可以将函数创建为
f <- function(x, n) if(n ==1) x else (x - 1) %% n + 1
f(1:5, 1)
#[1] 1 2 3 4 5
f(1:5, 2)
#[1] 1 2 1 2 1
f(1:5, 3)
#[1] 1 2 3 1 2
f(5:1, 3)
#[1] 2 1 3 2 1
f(c(3, 6), 3)
#[1] 3 3