学習環境
- Surface 3 (4G LTE)、Surface 3 タイプ カバー、Surface ペン(端末)
- Windows 10 Pro (OS)
- 数式入力ソフト(TeX, MathML): MathType
- MathML対応ブラウザ: Firefox、Safari
- MathML非対応ブラウザ(Internet Explorer, Google Chrome...)用JavaScript Library: MathJax
数学読本〈4〉数列の極限,順列/順列・組合せ/確率/関数の極限と微分法(松坂 和夫(著)、岩波書店)の第15章(「場合の数」 を数える - 順列・組合せ)、15.2(組合せ)、包除原理の一般公式、問35.を取り組んでみる。
コード(Emacs)
HTML5
n = <input id="n0" type="number" min="1" step="1" value="6"> <br> <button id="run0">run</button> <button id="clear0">clear</button> <pre id="output0"></pre> <script src="sample35.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 range = (start, end, step=1) => { let iter = (i, result) => { return i >= end ? result : iter(i + step, result.concat([i])); } return iter(start, []); }; let factorial = (n) => { return n <= 1 ? 1 : n * factorial(n - 1); }; let combination = (n, r) => { return factorial(n) / (factorial(r) * factorial(n - r)); }; let k = (n, i) => { return Math.pow(-1, i) * combination(n, i) * factorial(n - i); }; let output = () => { let n = parseInt(input0.value, 10); p(range(0, n + 1).reduce((prev, i) => prev += k(n, i), 0)); }; btn0.onclick = output; btn1.onclick = () => { pre0.textContent = ''; }; output();n =
0 コメント:
コメントを投稿