为的是让一个合数只让最小的一个素数筛去
prime[]数组中的素数是递增的,当i能整除prime[j],那么i*prime[j+1]这个合数肯定被prime[j]乘以某个数筛掉。因为i中含有prime[j],prime[j]比prime[j+1]小,即i=k*prime[j],那么i*prime[j+1]=(k*prime[j])*prime [j+1]=k’*prime[j],接下去的素数同理。所以不用筛下去了。因此,在满足i%prime[j]==0这个条件之前以及第一次满足改条件时,prime[j]必定是prime[j]*i的最小因子。

本文探讨欧拉筛法与普通筛法在筛选素数过程中的差异,重点在于欧拉筛法如何确保合数只由其最小素因数筛除,通过分析prime数组的递增性质,解释了为何在满足特定条件前,欧拉筛法能避免冗余计算。
951

被折叠的 条评论
为什么被折叠?



