当前位置:首页 > PHP教程 > php应用 > 列表

使用PHP求最大奇约数的和

发布:smiling 来源: PHP粉丝网  添加日期:2022-06-06 08:31:34 浏览: 评论:0 

本篇文章介绍一下使用PHP如何求最大奇约数的和,有一定的参考价值,有需要的朋友可以参考一下,希望对大家有所帮助。

小易是一个数论爱好者,并且对于一个数的奇数约数十分感兴趣。一天小易遇到这样一个问题: 定义函数f(x)为x最大的奇数约数,x为正整数。 例如:f(44) = 11.

现在给出一个N,需要求出 f(1) + f(2) + f(3)…….f(N)

例如: N = 7

f(1) + f(2) + f(3) + f(4) + f(5) + f(6) + f(7) = 1 + 1 + 3 + 1 + 5 + 3 + 7 = 21

小易计算这个问题遇到了困难,需要你来设计一个算法帮助他。

  1. <?php 
  2.  
  3. $num = trim(fgets(STDIN)); 
  4.  
  5.  
  6.  
  7. function jNum($num){ 
  8.  
  9.         $m = $num/2; 
  10.  
  11.         $res = 1; 
  12.  
  13.         if($num&0x1 == 1){//如果他本身就是个奇数,那么他的最大奇约数就是他本身 
  14.  
  15.                 $res = $num
  16.  
  17.                 goto HELL; 
  18.  
  19.         } 
  20.  
  21.         for($i = 1; $i<=$m$i=$i+2){//如果不是,那么就从1开始一直往上除,每次+2(奇数) 
  22.  
  23.                 if($num%$i==0){ 
  24.  
  25.                         $res = $i
  26.  
  27.                 } 
  28.  
  29.         } 
  30.  
  31.         HELL: 
  32.  
  33.         return $res
  34.  
  35.  
  36.  
  37.  
  38. function jNum2($num
  39.  
  40.  
  41.         $res = 0; 
  42.  
  43.  
  44.  
  45.         for($i=1;$i<=$num;$i++){ 
  46.  
  47.                 if(($i&0x1) == 1){//如果他本身就是个奇数,那么他的最大奇约数就是他本身 
  48.  
  49.                         $res+=$i
  50.  
  51.                 }else
  52.  
  53.                         $n = $i
  54.  
  55.                         while(true){//优化,从最大的数开始往下除 
  56.  
  57.                                 $n = $n>>1; 
  58.  
  59.                                 if(($n&0x1) == 1){ 
  60.  
  61.                                         $res+=$n
  62.  
  63.                                         break
  64.  
  65.                                 } 
  66.  
  67.                         } 
  68.  
  69.                 } 
  70.  
  71.         } 
  72.  
  73.  
  74.  
  75.         HELL: 
  76.  
  77.         return $res
  78.  
  79.  
  80.  
  81.  
  82. function jNum3($num){//公式法 
  83.  
  84.         if($num == 1){ 
  85.  
  86.                 return 1; 
  87.  
  88.         } 
  89.  
  90.         if(($num&0x1) == 0){ 
  91.  
  92.                 return jNum3($num>>1)+$num*$num/4; 
  93.  
  94.         }else
  95.  
  96.                 return jNum3($num-1)+$num
  97.  
  98.         } 
  99.  
  100.  
  101.  
  102.  
  103. //$sum = 0; 
  104.  
  105. //for($i = 1; $i<=$num; $i++){ 
  106.  
  107. //      $sum+=jNum($i); 
  108.  
  109. //} 
  110.  
  111. //echo $sum; 
  112.  
  113. //echo jNum2($num); 
  114.  
  115. echo jNum3($num); 

开始常规思路,一直调试的方法1,一直超时,改为方法2,还是超时,没有什么本质区别。

换思路。。

求sum(i)的过程中,如果i 为奇数可以直接求,就是 i 本身,即f(i) = i。

问题就是求所有f(i), i为偶数的和。

因为是最大奇约数,所以f(2k) = f(k),所以f(2) + f(4) + … + f(2k) = f(1) + f(2) + … + f(k);

所以,数学归纳法,可以求出通用公式

使用PHP求最大奇约数的和

这个做法还是不容易想到的。。。这么BT的题。。

本文转载自:https://blog.csdn.net/qq_28602957/article/details/77914402

Tags: PHP求最大奇约数的和

分享到: