iis服务器助手广告广告
返回顶部
首页 > 资讯 > 精选 >怎么用javascript正则表达式判断质数
  • 855
分享到

怎么用javascript正则表达式判断质数

2023-06-30 16:06:34 855人浏览 八月长安
摘要

这篇文章主要介绍“怎么用javascript正则表达式判断质数”,在日常操作中,相信很多人在怎么用javascript正则表达式判断质数问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”怎么用javascript

这篇文章主要介绍“怎么用javascript正则表达式判断质数”,在日常操作中,相信很多人在怎么用javascript正则表达式判断质数问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”怎么用javascript正则表达式判断质数”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!

示例

perl -wle 'print "Prime" if (1 x shift) !~ /^1?$|^(11+?)\1+$/' [number]

翻译js代码如下

function isPrime(n) {    return !/^1?$|^(11+?)\1+$/.test("1".repeat(n))}

代码逻辑非常简单,生成"1" * n长度的字符串,通过/^1?$|^(11+?)\1+$/正则表达式进行判断,再将结果取反

正则分析

/^1?$|^(11+?)\1+$/

上面正则表达式有2个分支,分别是

  • /^1?$

  • ^(11+?)\1+$

分支1 逻辑很简单,就是匹配0或者1个 "1",因为要排除数字1(非质数)

分支2 就有意思了,可以拆成2块来看

  • ^(11+?)

  • \1+$

表达式1,非贪婪模式下匹配 "11" "111" "1111"....,作为一个分组
表达式2,\1代表将表达式1匹配的结果赋值给\1,判断是否结尾,否的话会触发回溯(因为表达式1可能匹配多种情况)

举个例子就更清晰了,比如传入n = 9,分支1不满足可以直接忽略
^(11+?)\1+$

步骤匹配结果说明
step 11 1 1 1 1 1 1 1 1(11+?)匹配到"11"
step 21 1 1 1 1 1 1 1 1分组结果赋值给\1,那么正则就变成 "11"+$,继续匹配剩余的字符(7个"1")
step 31 1 1 1 1 1 1 1 1再重复3轮的匹配,发现剩余一个"1",不满足$,进行回溯
step 41 1 1 1 1 1 1 1 1还是不满足$,继续回溯
step 51 1 1 1 1 1 1 1 1一直回溯到step 1(11+?)匹配到"111"
step 61 1 1 1 1 1 1 1 1分组结果赋值给\1,那么正则就变成 "111"+$,继续匹配剩余的字符(6个"1")
step 71 1 1 1 1 1 1 1 1再重复2轮的匹配,满足$,匹配成功

原理

经过上述的分析,不难发现,其实回溯就是将数字不断除于2、3、4....,最后检查是否有余数,没有的话就匹配成功(非质数),非常简单粗暴的穷举法

优化空间

仔细看正则匹配的过程分析,其实step 3 ~ step 4的回溯完全没有必要,那么正则可以改写成这样/^1?$|^(11+?)\1+?$/,将\1+改成非贪婪模式\1+?,那么就放弃step 4回溯

性能测试

console.time('优化前')console.log(!/^1?$|^(11+?)\1+$/.test("1".repeat(33331)));console.timeEnd('优化前')console.time('优化后')console.log(!/^1?$|^(11+?)\1+?$/.test("1".repeat(33331)));console.timeEnd('优化后')// true// 优化前: 227.9189453125 ms// true// 优化后: 155.797119140625 ms

耗时上减少了接近一半

到此,关于“怎么用javascript正则表达式判断质数”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注编程网网站,小编会继续努力为大家带来更多实用的文章!

--结束END--

本文标题: 怎么用javascript正则表达式判断质数

本文链接: https://www.lsjlt.com/news/330260.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • 怎么用javascript正则表达式判断质数
    这篇文章主要介绍“怎么用javascript正则表达式判断质数”,在日常操作中,相信很多人在怎么用javascript正则表达式判断质数问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”怎么用javascript...
    99+
    2023-06-30
  • 一行正则表达式判断质数的代码
    目录背景示例正则分析原理优化空间性能测试总结背景 昨天无意中看到一篇大佬的文章Primality regex(正则表达式判断质数),惊为天人,正则表达式也能用来判断质数了?立马来研究...
    99+
    2022-11-13
  • JavaScript中怎么利用正则表达式判断匹配规则
    这篇文章将为大家详细讲解有关JavaScript中怎么利用正则表达式判断匹配规则,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。字符串是编程时涉及到的最多的一...
    99+
    2022-10-19
  • JavaScript正则表达式怎么用
    这篇文章主要为大家展示了“JavaScript正则表达式怎么用”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“JavaScript正则表达式怎么用”这篇文章吧。什...
    99+
    2022-10-19
  • JS如何使用正则表达式判断有效数
    这篇文章将为大家详细讲解有关JS如何使用正则表达式判断有效数,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。<script type="text/...
    99+
    2022-10-19
  • python 正则表达式判断URL是否合
    import re url = "http://www.baidu.com" if re.match(r'^https:/{2}\w.+$', url): print("Ok.") else: print("Error...
    99+
    2023-01-31
    正则表达式 python URL
  • Regex正则表达式判断密码强度
    目录需求在线测试Regex正文密码强度分类Regex分析中强度密码同理。高强度密码同理。补充:密码强度 弱 中 强 正则表达式判断需求   最近在最做一个软件的注...
    99+
    2023-02-01
    正则表达式判断密码强度 正则表达式判断密码
  • 怎么使用javascript正则表达式
    本篇内容介绍了“怎么使用javascript正则表达式”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!表单验...
    99+
    2022-10-19
  • JavaScript正则表达式怎么记
    这篇文章给大家分享的是有关JavaScript正则表达式怎么记的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。我们知道,正则表达式是一个处理字符串中很实用的技巧。然而,即便是Jav...
    99+
    2022-10-19
  • 怎么使用正则表达式判断是否有特殊字符
    使用正则表达式判断是否有特殊字符可以使用以下步骤:1. 定义一个正则表达式,匹配特殊字符。例如,可以使用`[^a-zA-Z0-9]`...
    99+
    2023-09-29
    正则表达式
  • 怎么理解javascript正则表达式
    本篇内容主要讲解“怎么理解javascript正则表达式”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“怎么理解javascript正则表达式”吧!javascr...
    99+
    2022-10-19
  • JavaScript正则表达式怎么创建
    本篇内容介绍了“JavaScript正则表达式怎么创建”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!1.JavaScript正则表达式的作用...
    99+
    2023-06-26
  • java使用正则表达式判断传入数据是否为数字
    可以利用正则表达式来“-[0-9]+(.[0-9]+)”来做判断字符串是否为数字。如果传入的数据有很多位,那么使用double会导致精度丢失,这个时候就要用BigDecimal来进行转换。实例: public class CheckS...
    99+
    2015-10-24
    java基础 java 正则表达式 判断 传入数据 数字
  • JavaScript中的正则表达式怎么应用
    本篇内容主要讲解“JavaScript中的正则表达式怎么应用”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“JavaScript中的正则表达式怎么应用”吧!  正则表达式(regular expr...
    99+
    2023-06-03
  • 正则表达式怎么表示数字
    正则表达式可以用来表示数字的方法有以下几种:1. 表示任意数字:\d,表示匹配任意一个数字字符。2. 表示零或多个数字:\d*,表示...
    99+
    2023-08-15
    正则表达式
  • java 判断字符串中有汉字 (常用正则表达式)
    今天在开发中碰到了判断字符串中是否有汉字的问题,方便起见,记录下来以便后期查看。 通过正则表达式判断 判断汉字 String address = "北京市朝阳区阜通东大街6号";String lonAndLat = "";Pattern p...
    99+
    2023-09-14
    正则表达式 java
  • 如何使用正则表达式判断邮箱(以C#为例)
    目录首先引入正则需要使用的命名空间判断是否为QQ邮箱判断是否为邮箱补充:C#正则表达式(Regex类)总结日常开发中,判断邮箱是少不了的,这个我以**C#**为例,来写一个判断方法,...
    99+
    2022-11-13
  • 怎样理解JavaScript 正则表达式
    今天就跟大家聊聊有关怎样理解JavaScript 正则表达式,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。1. 正则表达式创建JavaScript 有两种方式创建正则表达式:第一种:...
    99+
    2023-06-25
  • PHP 正则表达式判断手机号和身份证号
    在PHP编写的程序中,为了保证代码本身的流程安全,少不了对数据流进行一些效验的工作。而PHP给我提供了正则表达式验证函数,我们可以很方便的通过正则表达式的验证函数,来检查数据流是否符合标准。这个时候就需要进行数据上的判断 PHP正则表达式判...
    99+
    2023-09-03
    php 正则表达式 开发语言
  • Oracle正则表达式怎么用
    这篇文章给大家分享的是有关Oracle正则表达式怎么用的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。oracle正则表达式 ORACLE中的支持正则表达式的函数主要有下面四个: ...
    99+
    2022-10-18
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作