[英]R Apply function with if statements to every elements in list
我的清单很大,下面是trboot6
的示例
更新:我不想删除多余的“ 1”或“ -1”。 相反,我想将其更改为零。 我很抱歉
dput()
structure(list(`1` = c(-1, 1, -1, -1, -1, -1, -1, -1, -1, 1,
-1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
-1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1), `2` = c(-1,
-1, -1, 1, 1, 1, -1, -1, -1, -1, -1, -1, 1, 1, -1, -1, -1, -1,
-1, 1, 1, 1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, 1, 1,
-1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1), `3` = c(1, -1, -1,
-1, -1, -1, -1, -1, -1, -1, -1, -1, -1, 1, -1, -1, -1, -1, -1,
-1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
-1, -1, -1, 1, -1, -1, -1, -1, -1, -1, -1, -1, -1), `4` = c(-1,
-1, 1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1,
-1, -1, -1, -1, -1, -1, -1, 1, 1, -1, -1, -1, -1, 1, -1, -1,
-1, -1, -1, -1, -1, -1, -1, -1, -1, 1), .Names = c("1", "2", "3", "4"))
以下内容仅供参考
$ 1 : num [1:39] -1 1 -1 -1 -1 -1 -1 -1 -1 1 ...
$ 2 : num [1:46] -1 -1 -1 1 1 1 -1 -1 -1 -1 ...
$ 3 : num [1:48] 1 -1 -1 -1 -1 -1 -1 -1 -1 -1 ...
$ 4 : num [1:43] -1 -1 1 -1 -1 -1 -1 -1 -1 -1 ...
我想做的是检查每个列表中每对是否都有1和-1。 对在以下括号中表示:
$ 1 : num [1:39] (-1 1) (-1 -1) (-1 -1) (-1 -1) (-1 1) ...
$ 2 : num [1:46] (-1 -1) (-1 1) (1 1) (-1 -1) (-1 -1) ...
$ 3 : num [1:48] (1 -1) (-1 -1) (-1 -1) (-1 -1) (-1 -1) ...
$ 4 : num [1:43] (-1 -1) (1 -1) (-1 -1) (-1 -1) (-1 -1) ...
如果该对没有1和-1,那么我想将第二个相同的数字更改为零,也就是说,如果该对是(1 1)
,我将第二个1更改为零以获得'(1 0)'。 如果再次有1,我也将其更改为1。 然后,如果有-1,它将与前1个配对。
为了更好地编写代码,我使用了这样的逻辑,即总和应始终在-2和2之间,以使线对存在。 对不能为(1,-1)(-1,1)或(1,-1)(1,-1)。 因此,如果余额<-2或> 2,则必须删除最新数字。
这是上述逻辑的代码:
balboot<-0
fboot<- function(x) {
ifelse(x==-1,balboot<-balbbot-1,balboot<-balboot+1)
if(balboot==-2){x<-0
balboot=-1}
if(balboot==2){x<-0
balboot=1}
return(fboot)
}
rdtp<-lapply(trboot6, FUN=fboot)
运行此命令后,我得到警告:
In if (x == 1) { ... :
the condition has length > 1 and only the first element will be used
预期产量:
list '1': -1, 1, -1, 0, 0, 0, 0, 0, 0, 1, -1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0
list '2': -1, 0, 0, 1, 1, 0, -1, -1,0, 0, 0, 0, 1, 1, -1, -1, 0, 0, 0, 1, 1, 0, -1, -1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 1, -1, -1, 0, 0, 0, 0, 0, 0, 0, 0, 0
提前谢谢你的帮助。
因为我没有50个信誉点,所以我无法评论,如果将向量从一个元素移开并始终检查向量和移位向量之和始终等于0怎么办?
您不会使用apply,但是会使用一会儿条件,虽然它并不是一个好看的代码,但它应适用于列表中的每个向量。
我创建了一个向量x,它就像您列表中的向量一样(仅由-1和1组成)
x <- c(-1,1,-1,1,-1,1,-1,1,-1,1,-1,1,1,1,-1,-1,1,1,-1,1,-1,-1,1,-1,1,-1,1)
x1 <- x[-length(x)]
x2 <- x[-1]
y <- x1 + x2
while (length(which((x1+x2)!=0))>0) {
x <- x[- which((x1+x2)!=0)[1]]
x1 <- x[-length(x)]
x2 <- x[-1]
}
现在,如果我打印x
我的确删除了所有没有与先前元素形成一对(-1,1)或(1,-1)的元素。
x
[1] -1 1 -1 1 -1 1 -1 1 -1 1 -1 1 -1 1 -1 1 -1 1 -1 1 -1 1
我不确定这是否是您的要求,但希望它至少对您有所帮助。
我们可以定义一个接受向量x
,并检查“ pairs”。 如果对的总和不为0,则将对的第二项替换为0,然后继续沿向量进行检查。 我们使用i
和j
作为迭代器。
good_pairs <- function(x){
i <- 1
j <- 2
keepgoing <- TRUE
while(keepgoing){
#grab a pair and sum it
pair <- x[c(i, j)]
pair_sum <- sum(pair)
while(pair_sum != 0){ #continue iterating until sum == 0
#replace i + 1 element with 0
x[j] <- 0
j <- j + 1
#break if we've run out of elements
if(is.na(x[j])){
break
}else{
#check the pair
pair <- x[c(i, j)]
pair_sum <- sum(pair)
}
}
#increment
i <- j + 1
j <- j + 2
keepgoing <- (length(x) > i)
}
x
}
lapply(trboot6, good_pairs)
[[1]]
[1] -1 1 -1 0 0 0 0 0 0 1 -1 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0
[[2]]
[1] -1 0 0 1 1 0 -1 -1 0 0 0 0 1 1 -1 -1 0 0 0 1 1 0 -1 -1 0 0 0 0 0 0 0 0 0 1 1 -1 -1 0 0 0 0 0 0 0
[45] 0 0
[[3]]
[1] 1 -1 -1 0 0 0 0 0 0 0 0 0 0 1 -1 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 1 -1 0 0 0 0
[45] 0 0 0 0
[[4]]
[1] -1 0 1 -1 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 1 1 -1 -1 0 0 1 -1 0 0 0 0 0 0 0 0 0 0 1
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.