-1

请帮助打印系列以及 1*3-3*5+5*7 等系列的总和,最多 n 个术语我在 php 中使用过这样的代码

class series {
    function ser(){
        $i = 0;
        $k = 3;
        $m = 0;

        for($j = 1; $j < 3; $j++) {
            if($j % 2 == 0 ) {
                $m = $i + ($i * $k);
            } else {
                $m=$m-($i*$k);

            }
        }

        //$m = $m + $i;
        echo "$m";
    }
}

$se = new series();
$se->ser();

只是我测试了2次

4

4 回答 4

8

通过一些简单的操作,我们可以找到求和 S 的公式。如果 n 是偶数 (sum Se),则添加成对项得到

 Se = (1*3 - 3*5) + (5*7 - 7*9) + (9*11 - 11*13) ...
 Se = -4*(  3 + 7 + 11 + ...  )

括号中的项可以拆分总结:

 Se = -4*( 1+2 + 3+4 + 5+6 + ...  )
 Se = -4*( n*(n+1)/2 )
 Se = -2*n*(n+1)

如果 n 是奇数(总和 So),则必须将最后一项添加到 Se:

 So = Se + 4*n*n-1
 So = +2*n*(n+1) - 1

C中的实现:

int series ( unsigned int n )
{
  if ( n%2 == 0 )
    return -2*n*(n+1);
  else
    return +2*n*(n+1) - 1;
}
于 2009-12-13T10:12:34.610 回答
5

这可能是家庭作业,但无论如何都要进行。希望你能从中学到一些东西。

上面的代码太可怕了。太复杂了……这是一个非常简单的版本。我不知道这是什么语言,但我会为你做一些类似的事情......去买一本关于编程的书,这将是你时间的明智投资。

function my_sum(int $count) {
    $result = 0;
    $sign = 1;
    for ($i=1; $i<=$count; $i++) {
        $result = $result + $sign * (2*$i-1) * (2*$i+1);
        $sign = - $sign;
    }
    return $result;
}

希望这会有所帮助...您可能对此有所了解。

于 2009-12-12T04:42:04.040 回答
5

我更喜欢递归函数,通过这种方式你可以stackoverflow(woot!):):

public static int serie(int n){
    if(n<1){
        return 0;
    }else{
        return (n%2==0?-1:1)*(4*n*n-1)+serie(n-1);
    }
}
于 2009-12-12T05:24:25.950 回答
1

或者,使用以下公式计算系列的前 n 项。抱歉还没有弄清楚如何让 SO 正确显示 LaTeX,也许有人可以为我编辑它,但如果你这样做,请留下评论并附上说明!

\frac{1}{2} \left(-4 (-1)^nn^2-4 (-1)^n n+(-1)^n-1\right)

或者,由精彩的EquationSheet.com生成:

替代文字
(来源:equationsheet.com

于 2009-12-12T10:37:48.503 回答