LeetCode:求小于n的所有的质数

本文探讨了如何使用算法和数据结构解决LeetCode中的问题,具体任务是找出所有小于给定数n的质数。通过解析解题思路,我们可以学习到有效的质数筛选方法。
摘要由CSDN通过智能技术生成
题目描述:
给定一个数字n,求小于n的质数的个数.

Example 1:
Input:10
Output:4
其中[2,3,5,7]
解题思路:
这道题比较简单可以利用遍历法,判断是否为质数即可.
此外,可以根据艾拉托斯特尼筛法是非常常用的,判断一个整数是否是质数的方法.并且可以在判断一个整数n的时候,同时
判断所小于n的整数,因此非常适合这道题.其原理通俗易懂:从1到n遍历,假设当前遍历到m,则把所有小于n的,且是m的倍数
的整数标为和数.遍历完成后,没有被标为和的数字即为质数.
#include <iostream>
#include <vector>
#include <cmath>

using namespace std;

class Solution{
public:
    int countPrimes(int n){       
        if(n<=2){
            return 0;
        }

        int count=1,board=0;
        bool flag;
        for(auto i=3;i<n;i+=2){
            board=sqrt(i),flag=true;
            for(auto j=2;j<=board;j++){
                if(i%j==0){
                    flag=false;
                    break;
                }
            }
            if(flag){
                count++;
            }
        }
        return count;
    }

    int countprim
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

路上的追梦人

您的鼓励就是我最大的动力

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

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

打赏作者

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

抵扣说明:

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

余额充值