2017年4月11日火曜日

学習環境

数学読本〈4〉数列の極限,順列/順列・組合せ/確率/関数の極限と微分法(松坂 和夫(著)、岩波書店)の第15章(「場合の数」 を数える - 順列・組合せ)、15.2(組合せ)、集合の要素の個数に関するある公式、問29、30.を取り組んでみる。


    1. 1000÷3=333.3 333

    2. 1000÷5=200

    3. 1000÷15=66. 333+20066=467

    4. 100467=533

    1. 1000÷9=111.1 1000111=889

    2. 1000÷6=166. 1000÷18=55. 111+16655=222

    3. 1000222=778

    4. 16655=111

コード(Emacs)

HTML5

<button id="run0">run</button>
<button id="clear0">clear</button>
<pre id="output0"></pre>
<script src="sample29.js"></script>

JavaScript

let btn0 = document.querySelector('#run0'),
    btn1 = document.querySelector('#clear0'),
    pre0 = document.querySelector('#output0');

let range = (start, end, step=1) => {
    let iter = (i, result) => {
        return i >= end ? result : iter(i + step, result.concat([i]));
    }
    return iter(start, []);
};
let output = () => {
    let nums = range(1, 1001);
    
    pre0.textContent +=
        '29-1.\n' +
        nums.filter((n) => n % 3 === 0).length + '\n' +
        '29-2.\n' +
        nums.filter((n) => n % 5 === 0).length + '\n' +
        '29-3.\n' +
        nums.filter((n) => n % 3 === 0 || n % 5 === 0).length + '\n' +
        '29-4.\n' +
        nums.filter((n) => n % 3 !== 0 && n % 5 !== 0).length + '\n' +
        '30-1.\n' +
        nums.filter((n) => n % 9 !== 0).length + '\n' +
        '30-2.\n' +
        nums.filter((n) => n % 6 === 0 || n % 9 === 0).length + '\n' +
        '30-3.\n' +
        nums.filter((n) => n % 6 !== 0 && n % 9 !== 0).length + '\n' +
        '30-4.\n' +
        nums.filter((n) => n % 6 === 0 && n % 9 !== 0).length + '\n';
};

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

output();














						

0 コメント:

コメントを投稿