学習環境
- 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 コメント:
コメントを投稿