设为首页收藏本站

爱吱声

 找回密码
 注册
搜索
查看: 5314|回复: 9
打印 上一主题 下一主题

[科教沙龙] 小小的停留之四 幸运数

[复制链接]
  • TA的每日心情
    擦汗
    2020-3-23 00:29
  • 签到天数: 134 天

    [LV.7]分神

    跳转到指定楼层
    楼主
    发表于 2014-7-16 11:30:51 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
    上次说到  小小的停留之三 “计算机之父” 天才的数学家冯·诺伊曼8 v# w2 N  R4 }# J( \$ S; @1 p
    看冯·诺伊曼的故事,他有句名言:“若人们不相信数学简单,只因他们未意识到生命之复杂。”
    8 F% m0 w, W2 H* q: j
    $ A/ S+ r% i; T, j8 H7 ?* @他有个好朋友,据说是最好的朋友,是生于匈牙利的波兰犹太人数学家乌拉姆,这位先生曾参与曼克顿计划(核武器上有Teller-Ulam design,Teller指爱德华·泰勒)。他亦有参与研究核能推动的航天飞机。在纯数学上,遍历理论、数论、集合论和代数拓扑都有他的足迹。1 }1 M2 S* c. w8 }; C8 Y4 e
    . [, y& x5 U9 k3 k; L! ^& H
    所以我在这里要说的幸运数不是中餐馆的饼干里给你的数字,也不是买彩票开奖的数字,而是在1955年波兰数学家乌拉姆提出的一个自然数列,用类似埃拉托斯特尼筛法的算法后留下的整数集合。
    6 a; H1 J# l' L! L7 U" T3 s- y$ Z/ |
    In number theory, a lucky number is a natural number in a set which is generated by a "sieve" similar to the Sieve of Eratosthenes that generates the primes.
    # _( G" K6 _9 `+ h
    ! n/ ~3 `9 a0 ]0 g1 I; J幸运数的定义% ^! u- C9 \2 Y5 f# f* w3 |- f
    FORMULA       
    8 e9 w( U( M9 `Start with the natural numbers. Delete every 2nd number, leaving 1 3 5 7 ...; the 2nd number remaining is 3, so delete every 3rd number, leaving 1 3 7 9 13 15 ...; now delete every 7th number, leaving 1 3 7 9 13 ...; now delete every 9th number; etc.9 E% h% Y  `: g3 x- G  J; q5 D. G
    / Q& k0 n* H7 i/ V6 B
    具体一点来说说幸运数列怎么筛选出来的(喜欢数论的同学一定知道挑选素数的埃拉托斯特尼筛法,这个办法是类似的)+ l% @* b; U8 |$ e; a1 ~

    $ S4 L- `5 w; ]+ Z初始,从1开始的自然数列:
    5 m; D5 R2 o0 p( R5 |Begin with a list of integers starting with 1:
    $ W+ a+ `2 g( m+ x( n) K/ P1        2        3        4        5        6        7        8        9        10        11        12        13        14        15        16        17        18        19        20        21        22        23        24        25  ……: B1 A6 D8 W4 \& b3 J8 r3 N2 m2 y0 c

    # x$ l3 `7 l; o. D开始删除,在这个数列里,从2开始,首先是每隔2个数字,删除第二个数字。剩下来的数字是奇数~~
    3 O  ?" z, g( i. }# o: m# G剩下的数列如下:" p; z; t* {" [0 {, p7 Z' [0 g
    Every second number (all even numbers) is eliminated, leaving only the odd integers:$ \3 [( F+ i6 @* U
    1                3                5                7                9                11                13                15                17                19                21                23                25  ……
    , p0 t8 I) O! e
    0 p7 Z& b; e" f# Q( w接下来是3,每隔3个数字删除第三个。剩下的数列如下:8 y" u+ V/ Z0 W' `. T  S
    The second term in this sequence is 3. Every third number which remains in the list is eliminated:( l% {$ _& ]- U! U
    1                3                                7                9                                13                15                                19                21                                25  ……) a  R. c2 V" w; m. @
    - c7 n' d+ }6 L+ P' u
    现在接下来的数字是7,所以把上述数列中每第七个删除,剩下的数列是:$ R" j0 G  _" X
    The next surviving number is now 7, so every seventh number that remains is eliminated:
    1 @% e& I3 j1 _; c/ w1                3                                7                9                                13                15                                                21                                25  ……
    0 n/ @- }, Q( I' U' H6 Z- q8 C
    $ G0 L+ C# ]: x接下来是9,……
    0 j6 _: n3 L. o. q+ r这个过程可以一直无限继续下去,被幸运地留下来的数字就是幸运数。
    : d5 z0 Q% M( s
    : A0 k' v$ W" i6 v+ L" ?1, 3, 7, 9, 13, 15, 21, 25, 31, 33, 37, 43, 49, 51, 63, 67, 69, 73, 75, 79, 87, 93, 99, ... (sequence A000959 in OEIS).: |% N$ F' e# j; o& D' `
    在OEIS编号为A000959的数列就是Lucky numbers+ R* D: d! B% g. @9 O
    上述链接给了一个稍微长一点的幸运数列:
    ; a( ?" t+ z5 A; l- J( f' w1, 3, 7, 9, 13, 15, 21, 25, 31, 33, 37, 43, 49, 51, 63, 67, 69, 73, 75, 79, 87, 93, 99, 105, 111, 115, 127, 129, 133, 135, 141, 151, 159, 163, 169, 171, 189, 193, 195, 201, 205, 211, 219, 223, 231, 235, 237, 241, 259, 261, 267, 273, 283, 285, 289, 297, 303 ……' r7 U0 ~9 A; c7 V

    . p) ]4 Q8 l. Z/ t1 {有没有同样喜欢看数字的同学告诉我,你看了这个数列发现的是什么呢?4 [' T' G  V' q" x
    ; P/ ]8 Z* h2 p1 o( k  M6 i; I! Y
    1 W. r' ?6 R, ~# ]# T
    # D, i; |; z0 A- D4 @9 `. X
    第一个短一点的数列,我发现,1,3,5,7的平方(1,9,25,49)都是幸运数,但9的平方81就不是,于是马上想,那么是不是只有奇素数的平方才是幸运数呢?答案是不,11的平方也不是。于是叶子的第一个猜想就在几秒里被叶子证明是错误的。
    ! g2 f; G0 [5 P) A& J2 k/ O7 x6 E5 k9 w! ~! v, Q3 x
    数论里的各种数列是数学里最容易上手理解的,不过最迷人最折磨人的也是它。著名的例子就是哥德巴赫猜想(Goldbach's conjecture)。9 `  j1 Y$ m  j
    幸运数的挑选过程,类似上面提到过的埃拉托斯特尼筛法挑选素数的过程,同时也和这个著名猜想有关。
    9 X: `0 c, n! T2 D" C另外幸运数也曾经在正式进入书面讨论的时候被建议叫做 "the sieve of Josephus Flavius",因为它的挑选让大家想到著名的约瑟夫斯问题。
    ! N7 V3 o' ^$ |. [8 C
    " ]; m+ v  k8 H  Y- B1 f  \5 i暂时就到这里吧,接下去要不要继续聊引出来的概念和问题呢?, ?( Z# M! ^9 H; N/ v8 ~
    ; _" F3 ?& Y8 z& h* Z& ~% X
    **什么叫做Conjecture?  n: y( {1 k, s7 @1 L
    **约瑟夫斯问题。

    评分

    参与人数 9爱元 +49 收起 理由
    韦红雪 + 8
    喜欢就捧捧场 + 6 涨姿势
    独角兽 + 4 涨姿势
    Pipilu + 2 涨姿势
    农民家的狗 + 4

    查看全部评分

  • TA的每日心情
    擦汗
    2020-3-23 00:29
  • 签到天数: 134 天

    [LV.7]分神

    沙发
     楼主| 发表于 2014-7-16 21:26:40 | 只看该作者
    猜想(conjecture)和假说(Hypothesis)
    ) k( l9 M% @. h+ ~% F( j6 L* L  q
    猜想(conjecture)是一个看上去是真的,但尚未被证明的叙述。比如说上面提到的数学数列,因为它表现的没有规律和无限性,基于观察的某些结论,如果不能用科学逻辑的方法来证明在无限的未来它都是真的,那么之前所观察到的所有事实都仅仅是看上去是正确的。
    ; q. w# V! K2 W( V7 o" h+ E$ Q* f( {
    4 X4 N( w4 C* Z2 N) R' ]7 J当猜想被证明后,它便会成为定理。猜想一日未成为定理,数学家都要小心在逻辑结构之中使用这些猜想。
    % `# |/ q  Z& F# J& W7 @: ?* S$ S" l; L
    猜想主要因为类比推理和偶然发现的巧合而出现。数学家通常会使用不完全归纳法,来测试自己的猜想。例如费马曾经根据首四个费马数是素数,便猜想所有费马数都是素数(此猜想已被推翻)
    ; {5 I6 E3 {2 g: |
    1 b; w/ _. ]" h* I* S5 H9 F1 ~假说(Hypothesis),即指按照预先设定,对某种现象进行的解释,即根据已知的科学事实和科学原理,对所研究的自然现象及其规律性提出的推测和说明,而且数据经过详细的分类、归纳与分析,得到一个暂时性但是可以被接受的解释。任何一种科学理论在未得到实验确证之前表现为假设学说或假说。! {, c) l6 m7 }. A+ L0 r+ X  A2 ~
    " }6 Y0 T: l" z0 C: O) `. S. O# A
    有的假设还没有完全被科学方法所证明,也没有被任何一种科学方法所否定,但能够产生深远的影响。如1900年德国物理学家马克斯·普朗克为解决黑体辐射谱而首先提出量子论(量子假说)。

    评分

    参与人数 1爱元 +4 收起 理由
    独角兽 + 4 涨姿势

    查看全部评分

  • TA的每日心情
    慵懒
    2018-2-25 20:16
  • 签到天数: 128 天

    [LV.7]分神

    板凳
    发表于 2014-7-16 21:58:32 | 只看该作者
    不明觉厉

    点评

    你是先入为主地封闭了自己的思考。这个数列的筛选规则,只要会数数都能看懂的吧??  发表于 2014-7-17 06:46
  • TA的每日心情
    擦汗
    2020-3-23 00:29
  • 签到天数: 134 天

    [LV.7]分神

    地板
     楼主| 发表于 2014-7-17 06:50:45 | 只看该作者
    本帖最后由 到处停留的叶子 于 2014-7-16 17:53 编辑
    ' q: c/ H) v& q7 v9 S. ?' g+ _* |8 a: C; Q, {' p" K
    **约瑟夫斯问题    都教授
    5 X2 {* a  m: N% A, m$ {4 E5 Y! S* ]# M! w
    我们来聊聊约瑟夫斯问题。
    1 D* x( d% t7 Y" d
    - y. `* V% v+ N% P0 V% B; l有n个囚犯站成一个圆圈,准备处决。首先从一个人开始,越过k-2个人(因为第一个人已经被越过),并杀掉第k个人。接着,再越过k-1个人,并杀掉第k个人。这个过程沿着圆圈一直进行,直到最终只剩下一个人留下,这个人就可以继续活着。
    4 D) L8 h4 W6 ~& Y: X
    & S; @, F8 a7 c* v; G1 P( S* c6 u问题是,给定了n和k,一开始要站在什么地方才能避免被处决?. f, V% N2 S: |3 H; {& Z
    3 @+ ]8 }1 H, K. m/ C4 V' D0 L
    3 Y  D, e- q4 p6 z' ^% Q
    ---------------------------------------不思考的分割线---------------------------------------------3 K, B- W. l2 D
    据说这个问题是一个经常出现在计算机算法中的问题,不过当年我读书的时候对它并没有特别注意。在计算机编程的算法中,类似问题又称为约瑟夫环。老兵和神牛肯定比我清楚得多。我就不多说什么算法了。牛教授 兵教授  
    2 H' j- K2 z3 O9 S: K. F6 A* {- A8 j
    # i; L9 b: Y+ ]/ n2 e9 W---------------------------------------历史八卦的分割线----------------------------------
      j  f4 |" W* i0 H这个问题是以弗拉维奥·约瑟夫斯命名的,他是1世纪的一名犹太历史学家。! M! p6 k: N* N0 i
    据载,他在自己的日记中写道,他和他的40个战友被罗马军队包围在洞中。他们讨论是自杀还是被俘,最终决定自杀,并以抽签的方式决定谁杀掉谁。约瑟夫斯和另外一个人是最后两个留下的人。约瑟夫斯说服了那个人,他们将向罗马军队投降,不再自杀。约瑟夫斯把他的存活归因于运气或天意。   

    该用户从未签到

    5#
    发表于 2014-7-17 09:30:00 | 只看该作者
    到处停留的叶子 发表于 2014-7-17 06:50
    * T9 m' N5 T6 ?" a/ t**约瑟夫斯问题    都教授
    ' }* c% ^% V1 y' @$ O: V% n; ?' j. [- }; B3 U4 r
    我们来聊聊约瑟夫斯问题。
    + ^* c8 J. L3 Z2 K2 y
    1. 经过努力学习,这题我能用java编程做了,oh yeah!
    ' {& D( X* e+ i1 a3 `- O( B0 {' N: U: D8 u4 Q. K/ E) s
    2. 但叶子问我的不是编程。对于给定的k,我可以用倒推法硬推。但是,想了半天也没有想到不用推的直接算法。/ ]# ^; i2 [1 y/ s

    9 w# P% r: y; D推的方法如下:
    6 |* C9 X& ?4 M+ |7 Z' f' [/ `- c+ W% ~2 T! I2 t+ b
    n=1,就一号,跑不掉的7 W5 ~  e7 N0 m7 ^9 w
    n=2, 要站 (k+1) 模 n 那一号设a(2),比如 k=2, 则 a2=1 (号); 若 k=3, 则 a2=2 " o; H7 b% z) n5 \( V/ [) e  Z* `
    如此类推,n=i 时,要站在 a(i-1)+k 模 n 那一号。比如,k=6, n=19 时 要站在14号。
    & M' Q7 G0 p& J0 v- U8 H; o# I) F4 s) A. m8 x

    4 P5 n; [! w; r4 v  A0 s$ T. f' M" ^我算到k=6都找不出更直接的规律,不好玩

    评分

    参与人数 1爱元 +6 收起 理由
    到处停留的叶子 + 6 哇!!!

    查看全部评分

  • TA的每日心情
    擦汗
    2020-3-23 00:29
  • 签到天数: 134 天

    [LV.7]分神

    6#
     楼主| 发表于 2014-7-17 11:02:58 | 只看该作者
    本帖最后由 到处停留的叶子 于 2014-7-16 22:06 编辑
    8 y* ~7 C& p' k" g/ V, l
    独角兽 发表于 2014-7-16 20:30
    7 R: H6 g6 {1 l; N" m( S/ O1 O1. 经过努力学习,这题我能用java编程做了,oh yeah!
    ! e& \6 L( S- g! L0 a6 A
    & S$ W% ^5 K% G' p% R* K1 B2. 但叶子问我的不是编程。对于给定的k,我可以用 ...

    2 @' Z7 G# A; g
    3 |9 }  s  M! G$ h- W: @兽兽真是爱动脑筋啊~~我现在遇到这类问题第一想到的是打电话找高手解答,或者先在网上找找看
    ; k. o) Y4 P; }) |7 x7 ?) `
    : X3 _* M+ b4 Y% z0 x% U+ u在维基上看到K=2的解法和还有K≠2的通用解法,这里摘抄过来那段关于n的有趣分析。
    $ o* ^9 U3 E: h$ D) @: p. ]  v# x& I; K9 h; f
    还有下面我抄了两个通用算法,那个java的是不是和你做的一样啊?
    " p0 R) q/ ^9 @: z) n% r( l  p
    * k2 o1 @7 q; r1 y6 R-----------------------------不动脑筋的分割线--------------------------
    9 \- K& @! l( Q+ j7 q6 @$ @6 y  Q: v% }
    一个小心翼翼的Java例子:6 _8 k- \0 Z3 L$ U
    ' G5 h+ x: W, Z7 |8 s
    int josephus(int n, int k) {
    & L9 N/ `5 E. S5 t        return josephus(n, k, 1);) o6 |+ w' s: h8 z
      }
    9 w! J% A4 x; I8 D: Z( N  int josephus(int n, int k, int startingPoint) {, }2 |5 R0 A7 `/ r0 m
          if(n == 1)* k5 I: _& M6 U) V
              return 1;5 y) V% c" x7 b( x( @
          int newSp = (startingPoint + k - 2) % n + 1;
    , Y% E+ L  N! v$ I6 u
    ' L9 N0 n6 N! ~) y" h6 p      int survivor = josephus(n - 1, k, newSp);3 M* d0 G$ K+ Z, H7 S, x# O
          if (survivor < newSp) {/ I+ d% _% {" R! `1 h
              return survivor;
    + F+ t+ E0 r& S. R! N+ A      } else5 v/ Y6 q2 P9 t
              return survivor + 1;
    6 r+ m: }$ H8 x# x0 _6 N  }3 P: M+ Y( U: L: x
    3 s: y: h  o- l3 d# e0 a  U
    另外有个更简洁的例子- c$ z* q$ \# v
      def josephus(n, k):1 |4 M- m% h3 `, @" J  i, @
        if n ==1:
    4 F  p( W5 t6 f4 _  b/ m      return 1
    % |+ f9 d. S! l* b: z    else:' Q! W5 D- V' C* q5 g" l2 S
          return ((josephus(n-1,k)+k-1) % n)+18 y8 a2 @- c3 P& C

    0 n- i3 b1 T( p; e4 F8 C& B' G(如果n这个数字很大很大,k很小很小,电脑会不会转晕过去呢?)% }- S+ F6 Q) A
    8 k! Q) Z7 B2 r+ d: a
    以上摘自 http://en.wikipedia.org/wiki/Josephus_problem#Solution0 i1 C3 b0 l/ ?- o

    ! f$ S  |4 h9 a; v
    1 p6 t# u9 W; d8 r3 W4 n关于n的分析:9 r3 \8 m& `$ i
    设f(n)为一开始有n个人时,生还者的位置。9 Q  A+ M: h' l( J9 G* Q
    如果一开始有偶数个人,则第二圈时位置为x的人一开始在第2x - 1个位置。因此位置为f(2n)的人开始时的位置为2f(n) - 1。这便给出了以下的递推公式:
    ) I; A' k2 i8 B5 ~
      |! p  O1 E, T7 B% g' O" uf(2n)=2f(n)-1/ ]' c2 D& b: P' s
    如果一开始有奇数个人,则走了一圈以后,最终是号码为1的人被杀。于是同样地,再走第二圈时,新的第二、第四、……个人被杀,等等。在这种情况下,位置为x的人原先位置为2x+1。这便给出了以下的递推公式:
    , [1 V. D# }; h5 C; D, N
    0 h8 [# u. o$ q' q0 e3 x+ cf(2n+1)=2f(n)+1+ ?  g2 A: M1 R! T, P& X; X$ x+ Q

    2 O8 s1 z& d( u2 s  x
    - ]+ ?" w4 ]% K! T+ g, h% p如果我们把n和f(n)的值列成表,我们可以看出一个规律:8 N( {7 D* ]5 i+ E4 q
    1 e$ \, t: c$ p, J* C* i% {
    n    1    2        3        4        5        6        7        8        9        10        11        12        13        14        15    16
    % {2 Q/ F6 K" l! w& Nf(n) 1    1        3        1        3        5        7        1        3        5        7        9        11        13        15        14 z1 N1 ?" L% J# a3 _

    ; A4 R* |" h; L" [6 g* S% X从中可以看出,f(n)是一个递增的奇数数列,每当n是2的幂时,便重新从f(n)=1开始。因此,如果我们选择m和l,使得n=2^m+l且0≤ l<2^m,那么f(n)=2 . l+1。显然,表格中的值满足这个方程。可以用数学归纳法给出一个证明。
    7 L* o3 \! M- N6 P" {/ @- W( u# H2 H. l
    定理:如果n=2^m+l且0≤ l<2^m,则f(n) = 2.l+1。  b  \9 c# {) F* p: r

    + e  U1 [0 [: F8 b2 u* n( N8 k7 j! T  ]3 s6 j
    答案的最漂亮的形式,与n的二进制表示有关:把n的第一位移动到最后,便得到f(n)。这可以通过把n表示为2^m+l来证明。

    该用户从未签到

    7#
    发表于 2014-7-17 11:19:06 | 只看该作者
    到处停留的叶子 发表于 2014-7-17 11:02 / }! _% F% M9 m0 B. Z
    兽兽真是爱动脑筋啊~~我现在遇到这类问题第一想到的是打电话找高手解答,或者先在网上找找看- l# I3 ~3 i' r. F2 J0 s% e9 w
    - \! A3 L+ g- Q: a1 [0 ]
    在 ...

    3 S- ^1 f* y& m6 B/ E/ U我的推法就是这个:
    ; v" O4 ]1 A/ A; h8 p& I
    1 z6 O) J, K) S1 a1 U, \. l: h  return ((josephus(n-1,k)+k-1) % n)+1
    ) I* u' P9 A# {' w! j" ~5 [' B
    , B& i% P0 c% W. R& {, \我有一点疏忽是如果整除,模的结果是0,但实际应该取n。所以这个表达式把 "+1"搞到括号外面就完全对了。! N! R2 q3 `# F6 V' J' I# A
    . m5 H4 t1 Y: A3 E, Q; `
    2的情况我没单拿出来搞。
  • TA的每日心情
    慵懒
    2020-5-10 00:00
  • 签到天数: 1237 天

    [LV.10]大乘

    8#
    发表于 2014-7-18 09:47:20 | 只看该作者
    绕死了
  • TA的每日心情
    慵懒
    昨天 09:26
  • 签到天数: 2159 天

    [LV.Master]无

    9#
    发表于 2014-7-18 22:40:37 | 只看该作者
    看不懂6 v- U% }4 T; b( O6 ]. G
    不过今天不幸运数是17
  • TA的每日心情
    擦汗
    2020-3-23 00:29
  • 签到天数: 134 天

    [LV.7]分神

    10#
     楼主| 发表于 2014-7-19 03:04:00 | 只看该作者
    常挨揍 发表于 2014-7-18 09:40 . u  O5 ~5 H* b; n# y, K
    看不懂
    6 z; g$ j' O& P8 a" }* I不过今天不幸运数是17

    * C; R- ^8 b& r' C3 {6 p8 x7月17日成了一个黑色的日子。很让人感觉生命无常。
    $ F. a* C2 X& {4 E3 q( l4 H" `' A
    以后出行挑日子,要找一个幸运数的交集,这里前面的9个数字也可以参考一下:1,3,7,9,13,15,21,25,315 O# q( U2 Q* k( }# i, r7 ^
    + N; }* b6 K/ _+ @0 ~) w
    13号如果遇上星期五,还是算了,不要不信邪。

    手机版|小黑屋|Archiver|网站错误报告|爱吱声   

    GMT+8, 2025-9-22 10:21 , Processed in 0.067185 second(s), 22 queries , Gzip On.

    Powered by Discuz! X3.2

    © 2001-2013 Comsenz Inc.

    快速回复 返回顶部 返回列表