【c++笔记】用c++解决一系列质数问题!

        质数是c语言和c++中比较常见的数学问题,本篇文章将带你走进有关质数的一系列基础问题,其中包含常见的思路总结,本篇文章过后,将会持续更新c++算法系列,感兴趣的话麻烦点个关注吧!

希望能给您带来帮助,谢谢您的观看!

目录

题目一:质数口袋

题目二:回文质数 Prime Palindromes

题目三:质数筛​编辑

 题目四:质因数分解

 做题总结:

①判断是否为质数的统一简单函数

②埃筛思想 

③一段时间以来对c语言与c++的感悟 


题目一:质数口袋

输入输出案例
输入100
输出
2
3
5
7
11
13
17
19
23
9

代码如下:

#include <bits/stdc++.h>
using namespace std;
int f(int n)
{int t=sqrt(n);for(int i=2;i<=t;i++){if(n%i==0){return 0;}}return n;
}int main()
{int a,sum=0,coun=0;cin>>a;for(int i=2;i<=a;i++){sum+=f(i);if(f(i)){printf("%d\n",i);coun++;} if(sum>=a)break;	}printf("%d",coun);return 0;
}

题目二:回文质数 Prime Palindromes

输入输出案例
输入5 500
输出
5
7
11
101
131
151
181
191
313
353
373
383

 代码如下:

#include <bits/stdc++.h>
using namespace std;
int f(int n)
{int t=sqrt(n);for(int i=2;i<=t;i++){if(n%i==0)return 0;}return n;
}void ff(int n)
{int t,m=0;t=n;while(n!=0)
{m=m*10+n%10;n=n/10;
}
if(m==t)
printf("%d\n",t);
}int main()
{int a,b,t;scanf("%d%d",&a,&b);for(int i=a;i<=b;i++){if(f(i)){ff(i);}	}return 0;
}

题目三:质数筛

输入输出案例
输入
5
3 4 5 6 7
输出3 5 7

代码如下 

#include <bits/stdc++.h>
using namespace std;
void st(long a[],long n)
{
for(int i=0;i<n;i++)
{for(int j=2;j<=a[i];j++){if(a[i]%j==0&&a[i]!=j){a[i]=0;break;}}if(a[i]!=0&&a[i]!=1)printf("%ld ",a[i]);
}
}
int main()
{long n;scanf("%ld",&n);long a[n];for(int i=0;i<n;i++)scanf("%ld",&a[i]);st(a,n);return 0; 
}

 题目四:质因数分解

输入输出案例
输入21
输出7

代码如下 

void st(int n)
{int i,j;printf("%d",j); 
}
int main()
{int n;scanf("%d",&n);st(n);return 0;
}

 做题总结:

①判断是否为质数的统一简单函数

int f(int n)
{int t=sqrt(n);for(int i=2;i<=t;i++){if(n%i==0)return 0;}return n;
}

很多情况下题目只要求质数部分,这个函数简单好用

②埃筛思想 

很多时候我们可以在数组中把质数定义为1,把非质数定义为0,这样就可以通过if条件语句对质数进行判断

同时这个方法对于把for循环条件里的i当作自然数的把握也十分有效

③一段时间以来对c语言与c++的感悟 

c语言与c++的写法实在是非常相同的,甚至很多时候只需要改一个头文件,但有的时候为了不tel,还是会选择性的去选择不同的函数,并且c++的函数较多,写代码时比较方便

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/418345.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Python武器库开发-武器库篇之Fofa-API使用(四十六)

Python武器库开发-武器库篇之Fofa-API使用(四十六) FOFA&#xff08;FOcus Observation of Futures Assets&#xff09;是一款专业的网络资产搜索引擎&#xff0c;旨在帮助企业发现和评估网络上的潜在安全风险。FOFA的基本原理是通过搜索引擎的方式&#xff0c;按照关键词对互…

【Linux上创建一个LVM卷组,将多个物理卷添加到卷组中使用】

Linux上创建一个LVM卷组&#xff0c;将多个物理卷添加到卷组中使用 目录1.列出当前系统中所有的块设备信息&#xff0c;包括磁盘、分区、逻辑卷等2.对磁盘进行分区操作3.创建了一个名为 vg_data 的卷组4.将物理卷添加到已经存在的卷组5.在卷组中创建一个逻辑卷6.查看已创建的 L…

2023:既是结束也是开始

2023年注定是不平凡的一年&#xff0c;这一年真的经历了很多事&#xff0c;包括学习、生活、工作等等&#xff0c;上半年忙着毕业以及一些其他的事情&#xff0c;很多挖的坑都没来得及填&#xff0c;下半年研一开学以后终于有了足够的时间学习&#xff0c;接下来就用这篇文章来…

cs231n assignment1——SVM

整体思路 加载CIFAR-10数据集并展示部分数据数据图像归一化&#xff0c;减去均值&#xff08;也可以再除以方差&#xff09;svm_loss_naive和svm_loss_vectorized计算hinge损失&#xff0c;用拉格朗日法列hinge损失函数利用随机梯度下降法优化SVM在训练集和验证集计算准确率&a…

VueCli-自定义创建项目

参考 1.安装脚手架 (已安装可以跳过) npm i vue/cli -g2.创建项目 vue create 项目名 // 如&#xff1a; vue create dn-demo键盘上下键 - 选择自定义选型 Vue CLI v5.0.8 ? Please pick a preset:Default ([Vue 3] babel, eslint)Default ([Vue 2] babel, eslint) > M…

文本处理方法:教你如何轻松批量删除多个文本文件中的空白行

在处理大量文本数据时&#xff0c;空白行可能会成为一个问题。这些无用的行不仅会使文本文件显得混乱&#xff0c;还可能影响数据的准确性和分析。幸运的是&#xff0c;有许多简单的方法可以批量删除多个文本文件中的空白行。下面来看“办公提效工具”如何批量操作的方法&#…

肌营养不良患者生活质量的“提升”

肌营养不良患者基本上是生活无法自理的&#xff0c;那么作为肌营养不良患者的家属&#xff0c;提升病人的生活质量就迫在眉睫。看了这篇文章你就知道该怎么做了。 ①保持生活环境整洁 肌营养不良患者本身体质较弱&#xff0c;而且后期会卧病在床&#xff0c;为了防止并发症的发…

强网杯2023 crypto

speed up 当时看到这个题目 也是觉得易懂 并且可以解出来的 但是数字实在是过大了兄弟 题目意思是计算2^27的阶乘,并获取得到每一位数的数字之和,flag即为该数字的sha256编码 2^27为134217728 gmpy2包是支持大数运算的,故利用其fac方法进行尝试,在等待一段时间后可以得到对…

范围运算between...and和空判断

目录 between...and 空判断 Oracle从入门到总裁:https://blog.csdn.net/weixin_67859959/article/details/135209645 between...and between...and的主要功能是用户进行范围查询,语法如下: select 字段 | 数值 between 最小值 and 最大值; 1.查询工资在 1500 ~ 3000 的所…

Day16 linuxC高级(存储类型 linux命令 shell命令)

文章目录 C补充标识常量存储类型1.auto // 自动型2.static&#xff1a;修饰变量和函数 // 静态型3.extern&#xff1a;外部引用4.register&#xff1a;寄存器类型 LinuxC高级简介&#xff1a;嵌入式系统(将软件嵌入到硬件里面)Linux起源查看操作系统版本内核系统架构系统关机或…

【GitHub项目推荐--全球首个开源图像识别系统】【转载】

你知道人脸识别、商品识别、车辆识别&#xff0c;以图搜图乃至自动驾驶&#xff0c;背后的技术是什么嘛&#xff1f;并不是图像分类、目标检测这些东西&#xff0c;而是综合使用目标检测、图像分类、度量学习、图像检索的【通用图像识别系统】… 度量学习是啥&#xff1f;图像检…

视频异常检测论文笔记

看几篇中文的学习一下别人的思路 基于全局-局部自注意力网络的视频异常检测方法主要贡献&#xff1a;网络结构注意力模块结构&#xff1a; 融合自注意力和自编码器的视频异常检测主要贡献&#xff1a;网络结构Transformer模块动态图 融合门控自注意力机制的生成对抗网络视频异常…