题解 | #KiKi求质数个数#
KiKi求质数个数
https://www.nowcoder.com/practice/d3a404ee0f8d41f98bf4707035d91086
fn main() { let mut count=0; for numbers in 100..1000 { if is_prime_number(numbers) { count+=1; } } println!("{}",count); } ///# 功能 /// 判断给定的一个整数是否是质数 /// # 参数 /// * `num` 输入的整数 /// # 返回 /// 是否是质数,是->true/不是->false /// # 示例 /// ``` /// //151 /// let result = is_prime_number(151); //判断整数151是不是质数 /// assert_eq!(result, false); //151只能分解为1*151显然不是质数 /// ``` /// ``` /// //153 /// let result = is_prime_number(153); //判断整数153不是质数 /// assert_eq!(result, false); //153可以分别出3*51大于一组公因数,因此不是质数 /// ``` /// # 备注 /// * 质数,指在大于1的自然数中,除了1和该数自身外,无法被其他自然数整除的数。 /// * 这里的循环以3开始,步长为2,即跳过了所有偶数(所有除了2以外的偶数都不是质数) /// * 当一个数不是质数时,必定存在两个约数,一个大于等于sqrt(n),另一个小于sqrt(n) fn is_prime_number(num: u32) -> bool { if num <= 3 { return true; } let mut i = 3; while i * i <= num { if num % 2 == 0 || num % i == 0 { return false; } i += 2; } return true; }