网友过招老杨:Gauss和Poincare数学问题的另类解法

大家应该还记得前几天我们的一篇文章:用SQL解一道有趣的数学题:Gauss和Poincare ,错过的朋友请先回顾。感谢网友的反馈,发来新的解法一则。

如网友所言:这个解法并没有颠覆性原解法,只是在一些数学逻辑上稍微有些不同,体现在SQL建模上的少许不同。

问题提出

这是一个流传已久的故事:

Gauss和Poincare在天堂相遇了,上帝说:你们都是人间最伟大的数学家,那我来出道题考考你们谁更聪明。我在左手写一个大于1小于100的数,在右手同样写一个大于1小于100的数,然后把他们的和写在Gauss手上,把积写在Poincare手上,看看你们能不能猜出这两个数字是几。

Gauss看了手上的数字,说:“我不知道这两个数字是几,可我保证Poincare也不知道。”

Poincare看了手上的数字,说:“我原来的确不知道那两个数字是几,可我现在知道了。”

Gauss说:“那我也知道了。”

问题:那两个数字是几?

网友新解

先看SQL逻辑和结果:

SQL> WITH T_NUM AS 2 (SELECT ROWNUM + 1 NUM FROM DUAL CONNECT BY LEVEL < 99) 3 SELECT A, B 4 FROM 5 ( 6 SELECT A, B,TOTAL,MUL,MUL_M, 7 COUNT(DECODE(MUL_M, 1, 1)) OVER (PARTITION BY TOTAL) MUL_N 8 FROM 9 ( 10 SELECT A, B,TOTAL,MUL,MUL_M 11 FROM 12 ( 13 SELECT 14 A, 15 B, 16 MUL, 17 TOTAL, 18 COUNT(TOTAL) OVER (PARTITION BY MUL) MUL_M 19 FROM 20 ( 21 SELECT 22 A, 23 B, 24 A + B TOTAL, 25 A * B MUL 26 FROM 27 (SELECT A.NUM A, 28 B.NUM B 29 FROM T_NUM A, T_NUM B 30 WHERE A.NUM+B.NUM-2 in( 31 SELECT NUM 32 FROM 33 ( 34 SELECT A.NUM * B.NUM NUM FROM T_NUM A, T_NUM B 35 WHERE A.NUM <= B.NUM 36 AND A.NUM > 1 37 AND B.NUM > 1 38 ) 39 WHERE MOD(NUM,2)=1 AND NUM < 99 40 ) 41 AND A.NUM < B.NUM 42 ) 43 ) 44 ) 45 WHERE MUL_M=1 46 ) 47 ) 48 WHERE MUL_N = 1; A B ---------- ---------- 4 13

剖析说明如下

高斯知道两数之和,不知道两数之积,但却可以肯定的说庞加莱不知道两数是什么。这说明两数之和决定了其对应的两数之积不可能分解为两个素因子。而根据哥德巴赫猜想(没错,就是陈景润做出了至今最好成绩中国人耳熟人详的那个猜想):任一大于2的偶数都可以写成两个素数之和。

这也就是说高斯看到的那个两数之和肯定不是偶数,一定是一个奇数。而一个奇数要写成两个素数的和,一定要包含2这个最小的素数,所以两数之和只要是2+奇合数的形式就一定不能表示成两个素数之和的形式。

分析下最内层的SQL:

21 SELECT 22 A, 23 B, 24 A + B TOTAL, 25 A * B MUL 26 FROM 27 (SELECT A.NUM A, 28 B.NUM B 29 FROM T_NUM A, T_NUM B 30 WHERE A.NUM+B.NUM-2 in( 31 SELECT NUM 32 FROM 33 ( 34 SELECT A.NUM * B.NUM NUM FROM T_NUM A, T_NUM B 35 WHERE A.NUM <= B.NUM 36 AND A.NUM > 1 37 AND B.NUM > 1 38 ) 39 WHERE MOD(NUM,2)=1 AND NUM < 99 40 ) 41 AND A.NUM < B.NUM 42 )

这一层的意思是构造出所有的两数之和减2的结果是奇数且是合数的所有可能性。到了这一步,高斯看到的两数之和就可以肯定的说,庞加莱一定不知道这两个数是什么。

接下来的一步,实现庞加莱知道了两个数是什么。

10 SELECT A, B,TOTAL,MUL,MUL_M 11 FROM 12 ( 13 SELECT 14 A, 15 B, 16 MUL, 17 TOTAL, 18 COUNT(TOTAL) OVER (PARTITION BY MUL) MUL_M 19 FROM 20 ( 21 SELECT 22 A, 23 B, 24 A + B TOTAL, 25 A * B MUL 26 FROM 27 (SELECT A.NUM A, 28 B.NUM B 29 FROM T_NUM A, T_NUM B 30 WHERE A.NUM+B.NUM-2 in( 31 SELECT NUM 32 FROM 33 ( 34 SELECT A.NUM * B.NUM NUM FROM T_NUM A, T_NUM B 35 WHERE A.NUM <= B.NUM 36 AND A.NUM > 1 37 AND B.NUM > 1 38 ) 39 WHERE MOD(NUM,2)=1 AND NUM < 99 40 ) 41 AND A.NUM < B.NUM 42 ) 43 ) 44 ) 45 WHERE MUL_M=1

这一步根据两数之积分组后的两数之和只有一种可能性的,也就是MUL_M=1,于是庞加莱就知道了,这两个数是什么。

最后一步,在上一步两数之积只有一种可能性的情况下,两数之和只有一种可能性的,也就是MUL_N=1,于是高斯也知道了这两个数是什么。

注意这个结果是正确的,思路也非常巧妙。于是杨长老忍不住技痒,再次操刀,就有了以下的改变。

杨长老对答

杨长老评价:能利用数学知识和算法来进行解题非常难得。

提几个小的问题:

1.在构造数组的时候已经排除了A和B等于1的情况

WITH T_NUM AS

(SELECT ROWNUM + 1 NUM FROM DUAL CONNECT BY LEVEL < 99)

因此36行和37行的判断不需要:

AND A.NUM > 1

AND B.NUM > 1

2.通过数学算法可以过滤掉一部分数据,可惜SQL上实现过滤的方法比较复杂,反而造成了更多的嵌套,单次执行逻辑读接近5000,根据楼主的含义进行了一下改写,逻辑读可以降到230左右:

WITH T_NUM AS (SELECT ROWNUM + 1 NUM FROM DUAL CONNECT BY LEVEL < 99), T_ALL AS (SELECT A.NUM A, B.NUM B, A.NUM + B.NUM TOTAL, A.NUM * B.NUM MUL FROM T_NUM A, T_NUM B WHERE A.NUM <= B.NUM) SELECT A, B FROM ( SELECT A, B,TOTAL,MUL,MUL_M, COUNT(DECODE(MUL_M, 1, 1)) OVER (PARTITION BY TOTAL) MUL_N FROM ( SELECT A, B,TOTAL,MUL,MUL_M FROM ( SELECT A, B, MUL, TOTAL, COUNT(TOTAL) OVER (PARTITION BY MUL) MUL_M FROM ( SELECT * FROM T_ALL WHERE A != B AND TOTAL - 2 IN ( SELECT MUL FROM T_ALL WHERE MOD(A, 2) = 1 AND MOD(B, 2) = 1 AND MUL < 99 ) ) ) WHERE MUL_M=1 ) ) WHERE MUL_N = 1;

不仅要实现功能,还是关注性能,这是SQL开发的精髓所在。

大家可以体验一下杨长老的强大底蕴和功力,而云和恩墨SQL审核产品和服务正是致力于提升SQL性能,改善用户体验。

近期文章

删繁就简-云和恩墨的一道面试题解析

用SQL解一道数学题:Gauss和Poincare

新年贺礼:云和恩墨大讲堂期刊发行

2015 Oracle 十大热门文章精选

Oracle 12c ASM 防火防盗新特性揭秘

DBA入门之路:学习与进阶之经验谈

DBA入门之路:关于日常工作的建议

数据驱动,成就未来。整合业界顶尖的技术与合作伙伴资源,围绕数据及相关领域,提供解决方案和专业服务。

业务架构

电子渠道(网络销售)分析系统、数据治理

IT基础架构

分布式存储解决方案

数据架构

Oracle DB2 MySQL NoSQL

专项服务:架构/安全/容灾/优化/整合/升级/迁移

运维服务:运维服务 代维服务

人才培养:个人认证 企业内训

软件产品:SQL审核、监控、数据恢复

应用架构

应用软件和中间件:数据建模 | SQL审核和优化 | 中间件服务

原文发布于微信公众号 - 数据和云(OraNews)

原文发表时间:2016-01-29

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏吉浦迅科技

NVIDIA发布新“掌中宝”开发套件:原来你是这样的Jetson Xavier

1374
来自专栏机器人网

无人机教程:说说入门那些事

无人机火爆的程度已无需多言。很多朋友或多或少地动过心思,想买一个无人机玩玩,那么,今天我们来说说,要想入门无人机,需要了解及掌握哪些东西呢? 我们将从无人机的...

36512
来自专栏机器人网

【干货】详解自动化机械臂维修&保养

自动化机械手可能会产生故障的原因:由于机械手衔接部位大大都是螺丝固定,可能会因为长时间震动形成螺丝松动松脱而形成机械手散架,部件的衔接块断裂等。另一方面机械手震...

3477
来自专栏龙行天下CSIEM

科学瞎想系列之三十九 船舶动力系统(5)

快期末考试了,给宝宝们归纳总结一下,划划重点。 1 船舶动力系统经历了三个阶段,你也可以理解成三代。一是传统的动力推进系统加辅机电站系统,这个阶段动力是...

2655
来自专栏机器人网

大疆在纽约发布全新口袋无人机Mavic Air:用户称更难选择了

1月23日晚间(当地时间1月22日上午10点),大疆在纽约发布全新口袋无人机Mavic Air,不管是技术还是价格,都介于Mavic Pro和Spark中间,有...

2735
来自专栏程序人生

代码结构的演进

过年了,各种公众号都在玩拜年,玩红包,甚至在玩喜羊羊,连程序君订阅的一些技术类的公号也不能免俗。作为大年三十还在苦逼上班的程序君,自然不会放过这个绝好的机会写点...

3225
来自专栏CreateAMind

手把手教你做无人驾驶汽车(一)

从DARPA无人车挑战赛(2004)开始,无人驾驶汽车就给人非常复杂难以开发的印象。随意感受一下:

791
来自专栏深入浅出区块链技术

什么是拜占庭将军问题

1224
来自专栏机器人网

Honeybee获NASA资助研究行星取样系统

Honeybee机器人获得了2份来自NASA小型企业创新研究(SBIR)阶段二的资助,用以进行彗星和行星取样技术的研究。阶段一的资助始于2013年,用于开发测试...

2655
来自专栏安恒信息

黑客可以通过扬声器侵入电脑

借用人耳听不到的声波入侵电脑,然后通过系统的扬声器进行传输,听上去像是电影中的情节。但是,两名德国研究者表示,这种事并不只是传说。在一篇于11月份发表在《通讯期...

2715

扫描关注云+社区