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