2017年4月12日水曜日

開発環境

The Art of Computer Programming Volume 1 Fundamental Algorithms Third Edition 日本語版(Donald E. Knuth (著)、青木 孝 (著)、筧 一彦 (著)、鈴木 健一 (著)、長尾 高弘 (著)、有澤 誠 (その他)、和田 英一 (その他)、ドワンゴ)の第1章(基礎概念)、1.2(数学的な基礎)、演習問題3を取り組んでみる。


  1. n=1の時左辺の分母が0になる。n=2から考える。

    n=2 1 2 n=3 1 2 + 1 6 = 4 6 = 2 3 n=4 2 3 + 1 12 = 9 12 = 3 4 n1 n n1 n + 1 n( n+1 ) = n 2 1+1 n( n+1 ) = n n+1 1 1·2 + 1 2·3 +··· 1 ( n1 )n = n1 n

コード(Emacs)

HTML5

n = <input id="n0" type="number" min="2" step="1" value="10">
<br>
<button id="run0">run</button>
<button id="clear0">clear</button>
<pre id="output0"></pre>

<script src="sample3.js"></script>

JavaScript

let input0 = document.querySelector('#n0'),
    btn0 = document.querySelector('#run0'),
    btn1 = document.querySelector('#clear0'),
    pre0 = document.querySelector('#output0'),
    p = (x) => pre0.textContent += x + '\n';

let f = (n) => {
    let term = (n) => 1 / ((n - 1) * n);
    let iter = (i, result) => {
        if (i > n) {
            return result;
        }
        return iter(i + 1, result + term(i));
    };
    return iter(2, 0);
};

let g = (n) => {
    return (n - 1) / n;
};

let h = (n) => {
    return 3 / 2 - 1 / n;
};

let output = () => {
    let n = parseInt(input0.value, 10);

    for (let i = 2; i < 100; i += 1) {
        p(`${i}: ${f(i)} ${g(i)} ${h(i)}`);
    }
    p(`${n}: ${f(n)} ${g(n)} ${h(n)}`);
};
    

btn0.onclick = output;
btn1.onclick = () => {
    pre0.textContent = '';
};

output();
n =










 
						

0 コメント:

コメントを投稿

Comments on Google+: