最佳回答
if (any(sieve ==i)) { # 如果i在sieve里 也可以写成 if ( i %in% sieve ) { primes <- c(primes, i) # 把i放到prime里 sieve <- c(sieve[(seive %% i) != 0], i) #把所有sieve里i的整数倍数(除了i)取走 # %%是mod, 余数,所以 sieve[seive%%i) !=0]是所有seive里除以i余数不为0的数} 整个这段代码是找出所有比n小的质数 再问: 还是很混乱。。。能说下这个logic或者流程是怎样的吗 再答: ok,理解的关键是sieve里的值随着循环是一个越来越少,第一个循环,n=2,primes = c(2), sieve <- 之后,所以2的倍数都被移走,但是把i留下(这一句其实有错误,i不需要了,因为已经在primes里了)可以改成 sieve <- c(sieve[(seive %% i) != 0])第二个循环,i=3,i还在sieve里,所以这一次把3的倍数都移走了。第三步,i=4,i不再在sieve里了(第一步的时候4是2的倍数已经被移走了)。。。
最新回答共有2条回答
-
2026-04-02 07:57:56大方的睫毛
回复if (any(sieve ==i)) { # 如果i在sieve里 也可以写成 if ( i %in% sieve ) { primes <- c(primes, i) # 把i放到prime里 sieve <- c(sieve[(seive %% i) != 0], i) #把所有sieve里i的整数倍数(除了i)取走 # %%是mod, 余数,所以 sieve[seive%%i) !=0]是所有seive里除以i余数不为0的数} 整个这段代码是找出所有比n小的质数 再问: 还是很混乱。。。能说下这个logic或者流程是怎样的吗 再答: ok,理解的关键是sieve里的值随着循环是一个越来越少,第一个循环,n=2,primes = c(2), sieve <- 之后,所以2的倍数都被移走,但是把i留下(这一句其实有错误,i不需要了,因为已经在primes里了)可以改成 sieve <- c(sieve[(seive %% i) != 0])第二个循环,i=3,i还在sieve里,所以这一次把3的倍数都移走了。第三步,i=4,i不再在sieve里了(第一步的时候4是2的倍数已经被移走了)。。。
热门文章
- 康达学院专转本五年制
- 高考一个考场分ab卷吗
- not only but also用法
- 某物体做自由落体运动,从释放开始计时,则物体在前2s内的平均速度为______m/s,物体下落2m时的速度大小为______m/s.
- 三角函数公式大全表格
- 地理中考必背知识点2022
- 2013-2014学年小学六年级科学上学期期末考试试卷及答案
- 人教版2014-2015学年小学五年级英语第二学期期中教学质量检测试卷及答案
- 【Linux驱动开发】设备树详解(二)设备树语法详解
- 别跟客户扯细节
- 在别的城市买房子能落户吗
- 卖房前要把装修贷还完吗
- 高中政治教学提高教学效果的方法探究
- “互联网+”背景下的初中英语课堂教学改革与创新策略研究
- 2022年终止合同范本
- 租房合同范本范文
- 如何挑选土豆
- 如何挑选土鸡
