C程序在数组中找到最小和最大的质数

c程序在数组中找到最小和最大的质数

问题陈述

给定一个包含 n 个正整数的数组。我们必须找到素数具有最小值和最大值的数字。

如果给定的数组是 –

arr [] = {10, 4, 1, 12, 13, 7, 6, 2, 27, 33}then minimum prime number is 2 and maximum prime number is 13

算法

1. Find maximum number from given number. Let us call it maxNumber2. Generate prime numbers from 1 to maxNumber and store them in a dynamic array3. Iterate input array and use dynamic array to find prime number with minimum and maximum value

Example

的中文翻译为:

示例

#include #include #include #define SIZE(arr) (sizeof(arr) / sizeof(arr[0]))using namespace std;void printMinAndMaxPrimes(int *arr, int n){   int maxNumber = *max_element(arr, arr + n);   vector primes(maxNumber + 1, true);   primes[0] = primes[1] = false;   for (int p = 2; p * p <= maxNumber; ++i) {      if (primes[p]) {         for (int i = p * 2; i <= maxNumber; i += p) {            primes[p] = false;         }      }   }   int minPrime = INT_MAX;   int maxPrime = INT_MIN;   for (int i = 0; i < n; ++i) {      if (primes[arr[i]]) {         minPrime = min(minPrime, arr[i]);         maxPrime = max(maxPrime, arr[i]);      }   }   cout << "Prime number of min value = " << minPrime << "

"; cout << "Prime number of max value = " << maxPrime << "

";}int main(){ int arr [] = {10, 4, 1, 12, 13, 7, 6, 2, 27, 33}; printMinAndMaxPrimes(arr, SIZE(arr)); return 0;}

输出

当您编译并执行上述程序时,它会生成以下输出 −

Prime number of min value = 2Prime number of max value = 13

以上就是C程序在数组中找到最小和最大的质数的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1444407.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月17日 21:29:31
下一篇 2025年12月17日 21:29:59

相关推荐

  • Three.js中动态更换3D模型纹理的教程

    本教程详细介绍了如何在Three.js应用中,通过用户选择(如下拉菜单)动态更改GLTF、GLB、FBX等3D模型特定网格的纹理。文章涵盖了纹理加载、目标网格识别、材质更新的核心机制,并提供了代码示例和最佳实践,旨在帮助开发者实现模型外观的实时定制化。 在Three.js中,为3D模型(如GLTF、…

    2025年12月23日
    000
  • HTML5WebWorkers怎么用_HTML5WebWorkers后台线程的使用方法与实例

    Web Workers是HTML5的多线程机制,通过创建后台线程执行耗时任务,避免阻塞UI线程。1. 创建worker.js文件,编写耗时计算逻辑并监听消息;2. 主页面使用new Worker()加载Worker,通过postMessage发送数据,onmessage接收结果,实现主线程与Work…

    2025年12月23日
    000
  • 用numpy进行数组尺寸交换

    使用Numpy实现数组维度交换 Numpy是一个功能强大的Python库,用于进行科学计算和数据处理。它包含了丰富的函数和工具,可以方便地对数组进行各种操作,其中之一就是数组维度的交换。本文将介绍如何使用Numpy实现数组维度交换,并给出具体的代码示例。 首先,我们需要导入Numpy库: impor…

    2025年12月21日
    000
  • JavaScript Worker_javascript并行计算

    Web Worker是HTML5的API,可在独立线程运行JS代码,避免阻塞主线程;通过postMessage通信,适用于计算密集任务如质数筛选。 JavaScript 是单线程语言,主线程负责页面渲染、事件处理和脚本执行。当遇到大量计算任务时,容易造成页面卡顿。为了解决这个问题,JavaScrip…

    2025年12月21日
    000
  • js中reduce在数组的使用

    reduce方法用于将数组归约为单一值,通过累加器函数遍历元素,可实现求和、扁平化、统计和分组;需注意初始值设置以避免空数组报错。 在 JavaScript 中,reduce 是数组的一个高阶方法,用于将数组“归约”为一个单一的值。它通过遍历数组每个元素,执行一个累加器函数,最终返回一个结果。这个方…

    2025年12月21日
    000
  • JavaScript数学库开发

    答案:开发JavaScript数学库需明确功能范围,包括基础扩展、统计计算、数值处理等,使用ES模块组织代码,确保测试覆盖边界情况,并发布至npm。 开发一个JavaScript数学库,核心是提供简洁、可靠且易于使用的数学函数。这类库可以用于前端计算、数据处理或科学运算场景。重点在于封装常用但原生J…

    2025年12月20日
    000
  • JavaScript中的BigInt数据类型有哪些应用场景和限制?

    BigInt 可处理超大整数运算,适用于加密、大ID处理等场景,支持位操作但不兼容浮点数、JSON序列化及Math方法,且不可与Number混用。 BigInt 是 JavaScript 中用于表示任意精度整数的一种数据类型,它能处理超出 Number 类型安全范围的整数(即大于 2^53 – 1 …

    2025年12月20日
    000
  • 如何用WebAssembly SIMD加速图像处理算法?

    WebAssembly SIMD通过并行处理像素数据显著提升图像处理效率。它利用128位向量指令,在单个周期内同时操作多个数据,如对16个8位颜色通道执行加法或乘法,从而加速滤镜、颜色转换、卷积等计算密集型任务。相比传统JavaScript逐像素处理,SIMD减少了循环次数和CPU指令开销,结合Em…

    2025年12月20日
    000
  • 如何用WebGPU实现基于物理的渲染(PBR)材质?

    答案:WebGPU实现PBR需准备顶点与材质数据,加载纹理并构建渲染管线,通过WGSL着色器执行光照计算。具体包括:提供位置、法线、UV及切线等顶点数据;使用纹理或uniform传递baseColor、metallic、roughness等材质属性;加载IBL相关纹理(辐射度图、预过滤环境图、BRD…

    2025年12月20日
    000
  • Node.js中如何操作数组?

    Node.js中操作数组与JavaScript一致,常用方法包括push、pop、slice、splice等,处理大型数组时需关注性能,建议使用流式处理或for循环提升效率;读取文件转数组可通过fs模块读取后用split分割,复杂CSV推荐csv-parse库;数据过滤转换可用filter、map、…

    2025年12月20日
    000
  • javascript如何实现数组响应式更新

    javascript实现数组响应式更新的核心是拦截数组的修改操作并在修改后通知依赖更新;2. 由于直接修改数组不会触发setter,因此需通过拦截数组方法或使用proxy实现;3. 拦截数组方法是通过重写push、pop、shift、unshift、splice、sort、reverse等方法,在调…

    2025年12月20日 好文分享
    000
  • javascript如何交换数组的前后部分

    交换数组前后部分的核心是使用slice和concat方法实现非破坏性操作,1. 通过math.max和math.min确保分割索引在有效范围内;2. 使用slice(0, splitindex)提取前部分;3. 使用slice(splitindex)提取后部分;4. 用concat将后部分与前部分连…

    2025年12月20日
    000
  • javascript如何求数组交集

    javascript求数组交集的常见方法包括:1. 循环嵌套,时间复杂度为o(nm),性能较差;2. filter结合includes,代码简洁但时间复杂度仍为o(nm);3. 使用set,将一个数组转为set后遍历另一数组查找,时间复杂度为o(n+m),性能更优;4. 排序后双指针法,适用于有序数…

    2025年12月20日 好文分享
    000
  • javascript数组如何移除第一个元素

    要移除 javascript 数组的第一个元素,最常用的方法是使用 shift() 方法,它会直接修改原数组并返回被移除的元素;1. 使用 shift() 是最直接的方式,如 let firstelement = myarray.shift(),执行后原数组变为 [2, 3, 4, 5],first…

    2025年12月20日 好文分享
    000
  • javascript怎么删除数组中的特定元素

    使用filter()方法可创建一个不包含特定元素的新数组,且不改变原数组,适用于需要保持原数组不变的场景;2. 使用splice()方法可直接在原数组上删除指定元素,需先通过indexof()或findindex()获取索引,适用于需原地修改数组的场景;3. 删除多个相同元素时,filter()更简…

    2025年12月20日 好文分享
    000
  • js如何实现数组映射

    在javascript中,实现数组映射的核心方式是使用内置的 map() 方法。1. map() 方法通过接受一个回调函数,为原数组的每个元素生成新值,最终返回一个新数组,不修改原始数组,体现了函数式编程的不变性原则;2. 相较于 foreach() 和 for 循环,map() 更适合“一对一”数…

    2025年12月20日
    000
  • javascript数组如何比较大小

    javascript数组不能直接用>或 JavaScript数组本身并没有一个像数字那样直接的“大于”或“小于”操作符来比较大小。当你尝试用 > 或 < 去比较两个数组时,JavaScript会尝试将它们转换为原始值(通常是字符串),然后进行比较,这往往得不到你想要的结果。所以,当…

    2025年12月20日 好文分享
    000
  • javascript如何检查变量是否为数组

    判断 javascript 变量是否为数组的核心方法是使用 array.isarray(),因为它能准确识别数组类型且不受跨 frame 环境影响;2. instanceof 操作符也可用于判断,但在跨 frame 场景下可能失效,因其依赖原型链检查;3. 对于老旧浏览器,可使用 polyfill …

    2025年12月20日 好文分享
    100
  • js 怎样比较两个数组是否相同

    在javascript中不能直接用==或===比较数组,因为它们比较的是引用地址而非内容,即使两个数组元素相同,只要不是同一对象实例,结果就为false;要准确判断数组内容是否一致,需进行逐元素比较,对于只含原始类型的数组可使用浅层比较函数如shallowarrayequal,通过检查长度和ever…

    2025年12月20日
    000
  • javascript怎么实现数组环形缓冲区

    javascript实现环形缓冲区的核心是使用固定大小数组和头尾指针配合模运算实现高效fifo操作。1. 其应用场景包括实时数据流处理(如webrtc音视频帧)、固定大小日志记录、撤销重做功能、固定缓存和游戏事件队列,均需满足固定容量、先进先出、自动淘汰旧数据的需求。2. 性能优化策略包括合理设定初…

    2025年12月20日 好文分享
    100

发表回复

登录后才能评论
关注微信