R之踩坑:&与&&的区别

今天有个任务,要计算成绩落在所有成绩的均值加减标准差内的成绩占所有成绩的比重,于是首先算出均值和标准差(就这我还踩了好久的坑,太菜了太菜了):

# grade是dataframe类型的
sd_grade <- sd(as.numeric(unlist(list(grade))))
mean_grade <- mean(as.numeric(unlist(list(grade))))

然后就可以开心地算比重liao:

grade[(grade>mean_grade-sd_grade) && (grade<mean_grade+sd_grade)]

哎,等等执行这一句之后的结果怎么还会是grade呢,我首先怀疑是优先级之类的问题,于是严谨得加了一重又一重的括号,然而并没有什么用,在进一步展开之前,可以先看一下grade的具体内容。
在这里插入图片描述
此时我们换个比较方式再试一次:

grade[(grade>80) && (grade<90)]

在这里插入图片描述

发现了吗,第二次与第一次有何区别,为什么第一次全部被选中了,而第二次却获得了空的数据框——第一次时,数据框的第一个元素是符合筛选条件的,而第二次却不符合,这恰恰反映了&&与&的重要区别,在面对一个向量时,&&只会考虑向量的第一个元素,而其他元素就直接搬来第一次比较的结果。

所以,只要换成&,就平安无事了。

最后再补一个坑,这样筛选出来的数据类型并不是原来的dataframe,因此计算比率要这样子:

fac <- length(grade[(grade>mean_grade-sd_grade) & (grade<mean_grade+sd_grade)])/nrow(grade)
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

羊城迷鹿

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值