当前位置: 首页 > java >正文

【数论】素数

题目描述

给定一个正整数N,求出1到N中有多少个素数。

输入

一个正整数N(N≤10000000)

输出

一行一个整数,表示1到N中有多少个素数。

样例输入
10
样例输出
4

思路分析

本题采用埃拉斯托特尼筛法。该方法是列出所有小素数最有效的方法之一。

原理:从2开始到\sqrt{n},将每个素数的各个倍数,标记成合数。

其与试除法不同的关键之处,在于试除法是以素数来测试每个待测数能否被整除。

代码
#include<bits/stdc++.h>
#define ll long long
using namespace std;
const ll N=1e7+9;
ll n,ans,p[N];
int main(){ios::sync_with_stdio(0),cin.tie(0),cout.tie(0);cin>>n;for(ll i=2;i*i<=n;i++){for(ll j=i*i;j<=n;j+=i){p[j]=1;}}for(ll i=2;i<=n;i++){if(p[i]==0)ans++;}cout<<ans;return 0;
}

http://www.xdnf.cn/news/17210.html

相关文章:

  • 盲盒抽卡机小程序系统开发:打造个性化娱乐新平台
  • C语言基础_排序算法和二分法查找
  • Android 之 Kotlin中的符号
  • Unity模型显示在UI上
  • 以此芯p1芯片为例研究OpenHarmony上GPU (Vulkan) 加速在深度学习推理中的价值
  • 点赞服务完整消息流转过程详解(原方案,未使用Redis)
  • 学习嵌入式之硬件——ARM体系
  • 昇思+昇腾开发板+DeepSeek模型开发与适配
  • 豆包新模型与PromptPilot工具深度测评:AI应用开发的全流程突破
  • 自然语言处理基础—(1)
  • Java 工具类的“活化石”:Apache Commons 核心用法、性能陷阱与现代替代方案
  • linux-系统性能监控
  • [特殊字符]企业游学 | 探秘字节,解锁AI科技新密码
  • WebSocket 通信与 WebSocketpp 库使用指南
  • Java 大视界 -- 基于 Java 的大数据实时流处理在工业物联网设备故障预测与智能运维中的应用(384)
  • 【STL源码剖析】从源码看 vector:底层扩容逻辑与内存复用机制
  • golang的map
  • 【Linux】重生之从零开始学习运维之主从MGR高可用
  • 【C++】unordered系列容器使用及封装
  • WebStorm转VSCode:高效迁移指南
  • QML开发:QML中的基本元素
  • 项目设计模式草稿纸
  • Docker概述
  • chromedp 笔记
  • Prometheus监控学习-安装
  • LeetCode 112. 路径总和解题思路详解(BFS算法深入理解)
  • pipeline方法关系抽取--课堂笔记
  • SpringBoot AI心理学训练实战
  • 《计算机“十万个为什么”》之 面向对象 vs 面向过程:编程世界的积木与流水线
  • FastAPI快速入门P2:与SpringBoot比较