【算法设计与分析】素数测试问题——设计一个拉斯维加斯算法,对于给定的正整数,判断其是否为素数。

news2024/11/19 19:20:38

目录

    • 一、问题描述
    • 二、分析
    • 三、运行结果
    • 四、代码

一、问题描述

  试设计一个素数测试的偏真蒙特卡罗算法,对于测试的整数n,所述算法是一个关于logn的多项式时间算法。结合教材中素数测试的偏假蒙特卡罗算法,设计一个素数测试的拉斯维加斯算法。
数据输入: 由文件input.txt给出输入数据。第1行有1个正整数p。
结果输出: 将计算结果输出到文件output.txt。若正整数p是素数,则输出“YES”,否则输出“NO”。

二、分析

打开input.txt文本输入一个正整数。
在这里插入图片描述

三、运行结果

运行程序,打开output.txt文本可以知道此数是否是素数。
在这里插入图片描述

四、代码

#include<iostream>
#include<fstream>
#include<string>
using namespace std;

long Pow(int a, int b) //计算a的b次方
{
    int k;
    long s = 1;
    for (k = 1; k <= b; k++)
    {
        s *= a;
    }
    return s;
}

bool RandomPrimalityTest(int N) //蒙特卡罗测试
{
    srand((unsigned)time(NULL));//初始化随机种子
    int a = rand() % N; //随机产生小于N的整数
    if (a == 0)a = N - 1;
    long b = Pow(a, N - 1) - 1;
    if (b % N == 0)return true;
    else return false;
}

void RepeatCall(int N, int n = 100) //重复调用RandomPrimalityTest函数n次
{
    int k;
    int cnt = 0;
    const double precison = 0.90; //定义精度
    for (k = 1; k <= n; k++)if (RandomPrimalityTest(N)) cnt++;
    double e = cnt * 1.0 / n;
    if (e >= precison)
        cout << N << "YES" << endl;
    else
        cout << N << "NO" << endl;
}

int main()
{
    ifstream in("input.txt");
    ofstream out("output.txt");
    int N;
    in >> N;
    if (!in.good())
    {
        out << "输入异常!" << endl;
        in.clear();
        return 0;
    }
    RepeatCall(N);
    in.close();
    out.close();
}


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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

盛最多水的容器(力扣)双指针 JAVA

给定一个长度为 n 的整数数组 height 。有 n 条垂线&#xff0c;第 i 条线的两个端点是 (i, 0) 和 (i, height[i]) 。 找出其中的两条线&#xff0c;使得它们与 x 轴共同构成的容器可以容纳最多的水。 返回容器可以储存的最大水量。 说明&#xff1a;你不能倾斜容器。 输入&…

Tomcat安装配置及其出错的解决方法

文章目录 一、安装二、进行配置三、解决问题四、验证 一、安装 官网链接: https://tomcat.apache.org/ 1.选择 A r c h i v e s \color{red}{Archives} Archives 2.选择 T o m c a t \color{red}{Tomcat} Tomcat版本 3.在对应的版本中选择相对应的小版本 点击 b i n \color…

海盗船DDR5版本号VER命名规则

从华硕、技嘉、微星的内存QVL中可总结出如下规律 海盗船DDR5版本号命名规则 第一位数字 颗粒厂商 第二位数字 对应产品类型 第三位数字 DIE数 3 美光 01 A 4 三星 43 传统内存 02 B 5 海力士 53 非传统内存 03 C 04 D 05 E 8 …

JAVA线程池分析实现

1、定义线程池 /*** 使用给定的初始参数创建新的 ThreadPoolExecutor对象&#xff0c;就创建了一个线程池* param corePoolSize - 要保留在池中的线程数&#xff0c;即使它们处于空闲状态&#xff0c;若果allowCoreThreadTimeOut设置为ture&#xff0c;那么核心线程在keepAliv…

整理——xilinx FPGA 在线升级

一&#xff1a;xilinx FPGA 在线升级方案&#xff1a;&#xff08;系统搭建&#xff1a;MicroBlaze软核处理器&#xff0c;uart控制器&#xff0c;Axi-lite-user用户通信接口&#xff0c;MIG DDR3控制器&#xff0c;中断控制器等&#xff0c;以太网控制器&#xff09; 1.跑一个…

C#开发的OpenRA游戏之建造物品的窗口10

C#开发的OpenRA游戏之建造物品的窗口10 前面已经分析完成建造物品的过程,从物品进入队列,直到物品按时间进行生产完成。那么生产完成之后,又是怎么样放置到游戏的地图里面的呢?本文就来分析这个问题。 前面可以看到,当物品建造完成时,会在右边的面板上显示建造完成: 在…

类 模板 已经声明为非类 模板

类 模板 已经声明为非类 模板 解决方案 原因是在当前包下&#xff0c;已经定义了AA类 解决方案 更改模板类AA的类名

爬虫入门05——requests中的post请求

爬虫入门05——requests中的post请求 以百度翻译为例&#xff0c;我们如何输入内容后获取翻译后的结果呢 打开百度翻译的界面 右键单击后选择检查 点击网络 在翻译的框内输入内容&#xff0c;就以输入“你好”为例&#xff0c; 点击sug&#xff0c;点击标头&#xff0c…

Linux 文件系统

文章目录 一、设备专用文件&#xff08;设备文件&#xff09;设备 ID 二、磁盘与分区1. 磁盘驱动器2. 磁盘分区 三、文件系统四、i-nodeext2 中的 i-node 与数据块指针 五、虚拟文件系统&#xff08;VFS&#xff09;六、日志文件系统七、单根目录层级与挂载点 一、设备专用文件…

aidl原理

aidl 流程 为了方便理解&#xff0c;先将binder看做是一个黑盒子 aidl的流程图如下 demo连接添加链接描述 Androidstudio 会帮我们生成emotionAidlService&#xff0c;具体目录在n\build\generated\aidl_source_output_dir\debug\out\com\example\emotion\emotionAidlServic…

swiftUI和swift的区别

概述 SwiftUI是苹果公司推出的一种用于构建iOS、macOS、watchOS和tvOS应用程序界面的框架。它是基于Swift编程语言开发的&#xff0c;旨在简化UI开发过程并提供实时预览功能&#xff0c;使开发人员可以更快地构建出漂亮的应用程序界面。 Swift是苹果公司推出的一种面向对象的…

【QT】混合UI设计

虽然利用Designer和代码的设计方式都可以开发GUI&#xff0c;但是毫无疑问的是最有效的开发方式是利用两者进行混合开发。 下面这个实验例子来自《QT5.9 C开发指南》&#xff0c;我做了小部分修改&#xff0c;最终效果是这样&#xff1a; 图标导入 这次我们要开发的是一个有工…

AprilTag码估算平面法向量+相机标定

由于本人部分原创博客发布在古月居论坛&#xff0c;详细内容点击链接跳转&#xff1a; 1. AprilTag探索和原理分析 2. 相机标定&#xff0c;基于AprilTag估算平面法向量

web安全php基础_php常量及可变变量(魔术变量)

常量 php中常量是一个简单值的标识符。该值在脚本中不能改变。 一个常量由英文字母、下划线、和数字组成,但数字不能作为首字母出现。 (常量名不需要加 $ 修饰符)。 常量有两点需要特别注意的地方 常量在整个脚本中都可以使用。常量值被定义后&#xff0c;在脚本的其他任何…

企业级CDP数据工程实践(一):建设中的最佳实践

大家好&#xff0c;许久未见&#xff0c;我是云祁&#xff5e; 今天想和大家分享下 企业级CDP项目 建设中的数据工程实践。 在很多情况下&#xff0c;大家可能会将数据工程与ETL的过程画上等号&#xff0c;但实际上ETL只是数据工程的一部分&#xff0c;其工作量通常仅占整个数据…

I.MX6ULL_Linux_驱动篇(40)异步通知

在前面使用阻塞或者非阻塞的方式来读取驱动中按键值都是应用程序主动读取的&#xff0c;对于非阻塞方式来说还需要应用程序通过 poll 函数不断的轮询。最好的方式就是驱动程序能主动向应用程序发出通知&#xff0c;报告自己可以访问&#xff0c;然后应用程序在从驱动程序中读取…

Linux——进程信号(下)

目录 总结 一&#xff0c;信号保存 1.1 阻塞信号 2.2 信号在内核(操作系统)中的表示 2.3 系统接口 2.3.1 sigset_t信号集 2.3.2 信号集的操作函数 2.3.3 sigprocmask 2.3.4 sigpending 2.4 实验样例 三&#xff0c;信号处理 3.1 信号捕捉 3.2 sigaction接口 3.3 实验…

2022年真题 - 17 - 系统优化

系统优化 题目配置验证配置 题目 StorageSrv - 系统优化 系统资源限制设置&#xff1a;设置所有用户的硬件跟软件的最大进程数、最大文件打开数为65535&#xff1b;开启 IPv4 恶意 icmp 错误消息保护&#xff1b;开启 SYN 洪水攻击保护&#xff1b;允许系统打开的端口范围为 …

服务网关 Gateway

服务网关 Gateway 服务网关介绍Gateway 介绍Gateway 和 Nginx 网关的区别Gateway 核心概念Gateway工作流程 Gateway 案例Predicate&#xff08;断言&#xff09;After 路由谓词工厂Before路由谓词工厂Between 路由谓词工厂Cookie路由谓词工厂Header 路由谓词工厂Host 路由谓词工…

支付宝支付(六):小程序支付(Go+Gin+内网穿透)

一、前置条件 &#xff08;1&#xff09;go语言&#xff0c;1.18 &#xff08;2&#xff09;Gin、第三方依赖包&#xff1a;gopay【github.com/go-pay/gopay/alipay】https://github.com/go-pay/gopay/blob/main/doc/wechat_v3.md &#xff08;3&#xff09;支付宝支付相关信…