学習環境
- 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.3(二項定理)、多項定理、問43、44、45.を取り組んでみる。
コード(Emacs)
HTML5
<button id="run0">run</button> <button id="clear0">clear</button> <pre id="output0"></pre> <script src="sample43.js"></script>
JavaScript
let 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 multinomialCoefficient = (n, ...args) => { return factorial(n) / args.map(factorial).reduce((x, y) => x * y); }; let output = () => { p('43-1.'); p(multinomialCoefficient(7, 2, 1, 4)); p('43-2.'); p(multinomialCoefficient(7, 1, 3, 4)); p('43-3.'); p(multinomialCoefficient(6, 1, 2, 3)); p('43-4.'); p(multinomialCoefficient(6, 2, 2, 1, 1)); p('44.'); p(multinomialCoefficient(6, 2, 4, 0) * Math.pow(-2, 4)) p(multinomialCoefficient(6, 2, 1, 3) * -2 * Math.pow(5, 3)); p(multinomialCoefficient(6, 1, 1, 4) * -2 * Math.pow(5, 4)); p('45.'); p(multinomialCoefficient(7, 0, 2, 5) * Math.pow(-3, 2) * Math.pow(4, 5) + multinomialCoefficient(7, 1, 0, 6) * 1 * Math.pow(4, 6)); p(multinomialCoefficient(7, 0, 5, 2) * Math.pow(-3, 5) * Math.pow(4, 2) + multinomialCoefficient(7, 1, 3, 3) * Math.pow(-3, 3) * Math.pow(4, 3) + multinomialCoefficient(7, 2, 1, 4) * Math.pow(-3, 1) * Math.pow(4, 4)); p(multinomialCoefficient(7, 3, 4, 0) * Math.pow(-3, 4) + multinomialCoefficient(7, 4, 2, 1) * Math.pow(-3, 2) * 4 + multinomialCoefficient(7, 5, 0, 2) * Math.pow(4, 2)); }; btn0.onclick = output; btn1.onclick = () => { pre0.textContent = ''; }; output();
0 コメント:
コメントを投稿