质数筛法

  1. pub fn prime_numbers(max: usize) -> Vec<usize> {
  2. let mut result: Vec<usize> = Vec::new();
  3. if max >= 2 {
  4. result.push(2)
  5. }
  6. for i in (3..max + 1).step_by(2) {
  7. let stop: usize = (i as f64).sqrt() as usize + 1;
  8. let mut status: bool = true;
  9. for j in (3..stop).step_by(2) {
  10. if i % j == 0 {
  11. status = false
  12. }
  13. }
  14. if status {
  15. result.push(i)
  16. }
  17. }
  18. result
  19. }
  20. #[cfg(test)]
  21. mod tests {
  22. use super::*;
  23. #[test]
  24. fn basic() {
  25. assert_eq!(prime_numbers(0), vec![]);
  26. assert_eq!(prime_numbers(11), vec![2, 3, 5, 7, 11]);
  27. assert_eq!(prime_numbers(25), vec![2, 3, 5, 7, 11, 13, 17, 19, 23]);
  28. assert_eq!(
  29. prime_numbers(33),
  30. vec![2, 3, 5, 7, 11, 13, 17, 19, 23, 29, 31]
  31. );
  32. }
  33. }