news 2026/1/22 13:36:54

关于雷劈数的一些研究

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
关于雷劈数的一些研究

一、雷劈数的定义

背景:有个数学家走在路上看见一个 3025 的路牌被劈成 30 和 25 了,他发现

(

30

+

25

)

2

=

3025

,因此称这种数为雷劈数。

比较小的雷劈数有

81

=

(

8

+

1

)

2

,

100

=

(

10

+

0

)

2

雷劈数的定义大概为:将数

N

的十进制表示从某处分成两半

a

b

b

可以包含前导

0

,但不能为空),那么

(

a

+

b

)

2

=

N

二、雷劈数的求法

因为

b

可以包含前导

0

,所以考虑直接枚举

b

的位数

n

。这个时候十进制拼接就可以表示为

10

n

a

+

b

于是我们的方程变成了这样:

(

a

+

b

)

2

=

10

n

a

+

b

展开移项:

a

2

+

2

a

b

+

b

2

10

n

a

b

=

0

a

2

+

(

2

b

10

n

)

a

+

b

2

b

=

0

这是一个关于

a

的二次方程,想要有整数解必须满足判别式

Δ

=

(

2

b

10

n

)

2

4

(

b

2

b

)

为完全平方数,设为

c

2

因此

4

b

2

4

10

n

b

+

10

2

n

4

b

2

+

4

b

=

c

2

,即

4

(

10

n

1

)

b

=

10

2

n

c

2

b

也要是整数,因此

10

2

n

c

2

需要是

4

(

10

n

1

)

的倍数。我们只需要找出符合这个条件的

c

即可。

首先显然

10

2

n

4

的倍数,因此

c

只要是偶数就可以满足

4

的条件,我们之后再带上这个偶数的条件。现在去掉

4

之后,我们就需要找出

c

2

10

2

n

1

(

mod

10

n

1

)

,因为

10

n

1

(

mod

10

n

1

)

首先

P

=

10

n

1

显然不是一个质数,我们先考虑将其质因数分解为

i

p

a

i

i

。如果我们对于所有的

p

a

i

i

求出它们的合法解,那么将所有的可能组合全都用 exCRT 合并起来就可以获得

P

的所有合法解。

现在问题变成求

c

2

1

(

mod

p

a

i

i

)

。注意这不是一般的二次剩余问题,因为我们寻找的数的平方是

1

显然的,这种情况下

c

只能为

1

p

a

i

i

1

,把

1

移到

c

2

处然后因式分解即可证明。

于是我们求出了所有合法的

c

。如果遇到了奇数跳过即可。

对于每一个

c

,其有唯一对应的两组对偶解:

b

=

10

2

n

c

2

4

(

10

n

1

)

,

a

=

10

n

±

c

2

b

容易发现满足上面条件的

c

所对应的

a

b

一定合法。

于是整个问题就解决了,回顾一遍整体的流程:

枚举

b

的位数

n

P

=

10

n

1

分解为

k

i

=

1

p

a

i

i

对于每一个

p

a

i

i

的两种选法,将它们任意组合,形成

2

k

种不同的解,每一种都用 exCRT 合并得到对应的

c

在合法的

c

中加上

P

+

1

,然后枚举所有的

c

判断是否是偶数;

对前几步得到的每一个偶数

c

都还原出对应的两组

a

,

b

最后将得到的所有

(

a

+

b

)

2

从小到大排序。

实现有点困难,因为我带着高精度写的所以写了 17KB,目前 15 秒能算出

10

50

以内所有雷劈数。代码就不给了(

upd: 拿 python 重写了一下,只有不到 2kb 而且 0.5 秒能算

10

60

,我回去加一下优化的高精度库应该还能加速,Code

实际上现在瓶颈在于质因数分解,在目前能够快速分解的范围内(对应到输入就是 65 位左右)基本都能一秒跑完了,所以可能也就这样了吧。其它的加速就又回归到了质因数分解而这并不是我想研究的部分,如果有人会更快速的分解

10

n

1

也可以在此基础上进行优化。

特别鸣谢:

liqingyang,刷视频的时候看到了这个问题;

Grammar__hbw,把倍数关系转化为了剩余问题;

zhouyuhang,提出了剩余问题的大体解决方案;

OEIS A102766,验证了程序的较小项的正确性;

我自己,写+调了一晚上的史山;

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/1/21 23:07:26

15、优化Windows系统性能:媒体定制与系统分析指南

优化Windows系统性能:媒体定制与系统分析指南 1. 定制Windows媒体库 在Windows系统中,若要将其他计算机上录制的节目添加到媒体库以便观看,可按以下步骤操作: 1. 选择“录制电视”媒体库,然后点击“下一步”。 2. 选择“将文件夹添加到库”,再点击“下一步”。 3. 选…

作者头像 李华
网站建设 2026/1/21 14:24:23

【软考系统架构设计师】六、软件工程

软件工程是软考系统架构设计师考试的核心支柱模块,不仅是理解软件架构设计、系统集成等复杂内容的基础,更是案例分析题中 “架构设计方案落地”“项目风险控制” 等场景的核心依托。在历年考试中,该模块分值稳定在 8-10 分,覆盖单…

作者头像 李华
网站建设 2026/1/21 17:30:01

【Labelme数据操作】LabelMe标注批量复制工具 - 完整教程

1. 脚本功能介绍 本脚本用于批量复制LabelMe标注信息,特别适用于以下场景: 您有一批图片,其中物体位置、形状、大小基本相同您已经使用LabelMe标注了第一张图片您希望将第一张图片的标注信息快速复制到其他图片中需要自动适应不同图片的尺寸信…

作者头像 李华
网站建设 2026/1/17 1:20:50

数控滑台的基本概念

数控滑台是一种通过数控系统控制的精密线性运动装置,广泛应用于机床、自动化生产线、3D打印等领域。其核心组件包括导轨、滚珠丝杠、伺服电机和控制系统,能够实现高精度、高速度的定位与重复运动。数控滑台的工作原理数控滑台通过伺服电机驱动滚珠丝杠旋…

作者头像 李华
网站建设 2026/1/21 7:45:51

FMD辉芒微电子8位微控制器芯片,荣获“深圳市制造业单项冠军企业”认定

辉芒微电子8位微控制器芯片,凭借领先的技术实力、卓越的产品性能以及扎实的市场表现,成功入选深圳市工业和信息化局“深圳市制造业单项冠军企业”认定。何为“制造业单项冠军”?深圳市制造业单项冠军企业,特指那些长期专注于制造业…

作者头像 李华
网站建设 2026/1/20 6:14:25

Unity XR 编辑器VR设备模拟功能

1、导入包2、项目设置中启用这样在场景运行的时候,就能使用模拟器 模拟VR设备了鼠标平移 模拟VR头盔。按住键盘的左Shift键不松开,控制左手柄,按住键盘G键 模拟侧键(抓取)、鼠标左键模拟扳机键(Trigger键&a…

作者头像 李华