<snapdata remixID="9111074"><project name="dbitko-2020-01-07-iteration-practice-3" app="Snap! 5.4, http://snap.berkeley.edu" version="1"><notes></notes><thumbnail>data:image/png;base64,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</thumbnail><stage name="Stage" width="480" height="360" costume="0" color="255,255,255,1" tempo="60" threadsafe="false" penlog="false" volume="100" pan="0" lines="round" ternary="false" codify="false" inheritance="true" sublistIDs="false" scheduled="false" id="1"><pentrails>data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAeAAAAFoCAYAAACPNyggAAAOhUlEQVR4Xu3VwQkAAAjEMN1/abewn7jAQRC64wgQIECAAIF3gX1fNEiAAAECBAiMAHsCAgQIECAQCAhwgG6SAAECBAgIsB8gQIAAAQKBgAAH6CYJECBAgIAA+wECBAgQIBAICHCAbpIAAQIECAiwHyBAgAABAoGAAAfoJgkQIECAgAD7AQIECBAgEAgIcIBukgABAgQICLAfIECAAAECgYAAB+gmCRAgQICAAPsBAgQIECAQCAhwgG6SAAECBAgIsB8gQIAAAQKBgAAH6CYJECBAgIAA+wECBAgQIBAICHCAbpIAAQIECAiwHyBAgAABAoGAAAfoJgkQIECAgAD7AQIECBAgEAgIcIBukgABAgQICLAfIECAAAECgYAAB+gmCRAgQICAAPsBAgQIECAQCAhwgG6SAAECBAgIsB8gQIAAAQKBgAAH6CYJECBAgIAA+wECBAgQIBAICHCAbpIAAQIECAiwHyBAgAABAoGAAAfoJgkQIECAgAD7AQIECBAgEAgIcIBukgABAgQICLAfIECAAAECgYAAB+gmCRAgQICAAPsBAgQIECAQCAhwgG6SAAECBAgIsB8gQIAAAQKBgAAH6CYJECBAgIAA+wECBAgQIBAICHCAbpIAAQIECAiwHyBAgAABAoGAAAfoJgkQIECAgAD7AQIECBAgEAgIcIBukgABAgQICLAfIECAAAECgYAAB+gmCRAgQICAAPsBAgQIECAQCAhwgG6SAAECBAgIsB8gQIAAAQKBgAAH6CYJECBAgIAA+wECBAgQIBAICHCAbpIAAQIECAiwHyBAgAABAoGAAAfoJgkQIECAgAD7AQIECBAgEAgIcIBukgABAgQICLAfIECAAAECgYAAB+gmCRAgQICAAPsBAgQIECAQCAhwgG6SAAECBAgIsB8gQIAAAQKBgAAH6CYJECBAgIAA+wECBAgQIBAICHCAbpIAAQIECAiwHyBAgAABAoGAAAfoJgkQIECAgAD7AQIECBAgEAgIcIBukgABAgQICLAfIECAAAECgYAAB+gmCRAgQICAAPsBAgQIECAQCAhwgG6SAAECBAgIsB8gQIAAAQKBgAAH6CYJECBAgIAA+wECBAgQIBAICHCAbpIAAQIECAiwHyBAgAABAoGAAAfoJgkQIECAgAD7AQIECBAgEAgIcIBukgABAgQICLAfIECAAAECgYAAB+gmCRAgQICAAPsBAgQIECAQCAhwgG6SAAECBAgIsB8gQIAAAQKBgAAH6CYJECBAgIAA+wECBAgQIBAICHCAbpIAAQIECAiwHyBAgAABAoGAAAfoJgkQIECAgAD7AQIECBAgEAgIcIBukgABAgQICLAfIECAAAECgYAAB+gmCRAgQICAAPsBAgQIECAQCAhwgG6SAAECBAgIsB8gQIAAAQKBgAAH6CYJECBAgIAA+wECBAgQIBAICHCAbpIAAQIECAiwHyBAgAABAoGAAAfoJgkQIECAgAD7AQIECBAgEAgIcIBukgABAgQICLAfIECAAAECgYAAB+gmCRAgQICAAPsBAgQIECAQCAhwgG6SAAECBAgIsB8gQIAAAQKBgAAH6CYJECBAgIAA+wECBAgQIBAICHCAbpIAAQIECAiwHyBAgAABAoGAAAfoJgkQIECAgAD7AQIECBAgEAgIcIBukgABAgQICLAfIECAAAECgYAAB+gmCRAgQICAAPsBAgQIECAQCAhwgG6SAAECBAgIsB8gQIAAAQKBgAAH6CYJECBAgIAA+wECBAgQIBAICHCAbpIAAQIECAiwHyBAgAABAoGAAAfoJgkQIECAgAD7AQIECBAgEAgIcIBukgABAgQICLAfIECAAAECgYAAB+gmCRAgQICAAPsBAgQIECAQCAhwgG6SAAECBAgIsB8gQIAAAQKBgAAH6CYJECBAgIAA+wECBAgQIBAICHCAbpIAAQIECAiwHyBAgAABAoGAAAfoJgkQIECAgAD7AQIECBAgEAgIcIBukgABAgQICLAfIECAAAECgYAAB+gmCRAgQICAAPsBAgQIECAQCAhwgG6SAAECBAgIsB8gQIAAAQKBgAAH6CYJECBAgIAA+wECBAgQIBAICHCAbpIAAQIECAiwHyBAgAABAoGAAAfoJgkQIECAgAD7AQIECBAgEAgIcIBukgABAgQICLAfIECAAAECgYAAB+gmCRAgQICAAPsBAgQIECAQCAhwgG6SAAECBAgIsB8gQIAAAQKBgAAH6CYJECBAgIAA+wECBAgQIBAICHCAbpIAAQIECAiwHyBAgAABAoGAAAfoJgkQIECAgAD7AQIECBAgEAgIcIBukgABAgQICLAfIECAAAECgYAAB+gmCRAgQICAAPsBAgQIECAQCAhwgG6SAAECBAgIsB8gQIAAAQKBgAAH6CYJECBAgIAA+wECBAgQIBAICHCAbpIAAQIECAiwHyBAgAABAoGAAAfoJgkQIECAgAD7AQIECBAgEAgIcIBukgABAgQICLAfIECAAAECgYAAB+gmCRAgQICAAPsBAgQIECAQCAhwgG6SAAECBAgIsB8gQIAAAQKBgAAH6CYJECBAgIAA+wECBAgQIBAICHCAbpIAAQIECAiwHyBAgAABAoGAAAfoJgkQIECAgAD7AQIECBAgEAgIcIBukgABAgQICLAfIECAAAECgYAAB+gmCRAgQICAAPsBAgQIECAQCAhwgG6SAAECBAgIsB8gQIAAAQKBgAAH6CYJECBAgIAA+wECBAgQIBAICHCAbpIAAQIECAiwHyBAgAABAoGAAAfoJgkQIECAgAD7AQIECBAgEAgIcIBukgABAgQICLAfIECAAAECgYAAB+gmCRAgQICAAPsBAgQIECAQCAhwgG6SAAECBAgIsB8gQIAAAQKBgAAH6CYJECBAgIAA+wECBAgQIBAICHCAbpIAAQIECAiwHyBAgAABAoGAAAfoJgkQIECAgAD7AQIECBAgEAgIcIBukgABAgQICLAfIECAAAECgYAAB+gmCRAgQICAAPsBAgQIECAQCAhwgG6SAAECBAgIsB8gQIAAAQKBgAAH6CYJECBAgIAA+wECBAgQIBAICHCAbpIAAQIECAiwHyBAgAABAoGAAAfoJgkQIECAgAD7AQIECBAgEAgIcIBukgABAgQICLAfIECAAAECgYAAB+gmCRAgQICAAPsBAgQIECAQCAhwgG6SAAECBAgIsB8gQIAAAQKBgAAH6CYJECBAgIAA+wECBAgQIBAICHCAbpIAAQIECAiwHyBAgAABAoGAAAfoJgkQIECAgAD7AQIECBAgEAgIcIBukgABAgQICLAfIECAAAECgYAAB+gmCRAgQICAAPsBAgQIECAQCAhwgG6SAAECBAgIsB8gQIAAAQKBgAAH6CYJECBAgIAA+wECBAgQIBAICHCAbpIAAQIECAiwHyBAgAABAoGAAAfoJgkQIECAgAD7AQIECBAgEAgIcIBukgABAgQICLAfIECAAAECgYAAB+gmCRAgQICAAPsBAgQIECAQCAhwgG6SAAECBAgIsB8gQIAAAQKBgAAH6CYJECBAgIAA+wECBAgQIBAICHCAbpIAAQIECAiwHyBAgAABAoGAAAfoJgkQIECAgAD7AQIECBAgEAgIcIBukgABAgQICLAfIECAAAECgYAAB+gmCRAgQICAAPsBAgQIECAQCAhwgG6SAAECBAgIsB8gQIAAAQKBgAAH6CYJECBAgIAA+wECBAgQIBAICHCAbpIAAQIECAiwHyBAgAABAoGAAAfoJgkQIECAgAD7AQIECBAgEAgIcIBukgABAgQICLAfIECAAAECgYAAB+gmCRAgQICAAPsBAgQIECAQCAhwgG6SAAECBAgIsB8gQIAAAQKBgAAH6CYJECBAgIAA+wECBAgQIBAICHCAbpIAAQIECAiwHyBAgAABAoGAAAfoJgkQIECAgAD7AQIECBAgEAgIcIBukgABAgQICLAfIECAAAECgYAAB+gmCRAgQICAAPsBAgQIECAQCAhwgG6SAAECBAgIsB8gQIAAAQKBgAAH6CYJECBAgIAA+wECBAgQIBAICHCAbpIAAQIECAiwHyBAgAABAoGAAAfoJgkQIECAgAD7AQIECBAgEAgIcIBukgABAgQICLAfIECAAAECgYAAB+gmCRAgQICAAPsBAgQIECAQCAhwgG6SAAECBAgIsB8gQIAAAQKBgAAH6CYJECBAgIAA+wECBAgQIBAICHCAbpIAAQIECAiwHyBAgAABAoGAAAfoJgkQIECAgAD7AQIECBAgEAgIcIBukgABAgQICLAfIECAAAECgYAAB+gmCRAgQICAAPsBAgQIECAQCAhwgG6SAAECBAgIsB8gQIAAAQKBgAAH6CYJECBAgIAA+wECBAgQIBAICHCAbpIAAQIECAiwHyBAgAABAoGAAAfoJgkQIECAgAD7AQIECBAgEAgIcIBukgABAgQICLAfIECAAAECgYAAB+gmCRAgQICAAPsBAgQIECAQCAhwgG6SAAECBAgIsB8gQIAAAQKBgAAH6CYJECBAgIAA+wECBAgQIBAICHCAbpIAAQIECAiwHyBAgAABAoGAAAfoJgkQIECAgAD7AQIECBAgEAgIcIBukgABAgQICLAfIECAAAECgYAAB+gmCRAgQICAAPsBAgQIECAQCAhwgG6SAAECBAgIsB8gQIAAAQKBgAAH6CYJECBAgIAA+wECBAgQIBAICHCAbpIAAQIECAiwHyBAgAABAoGAAAfoJgkQIECAgAD7AQIECBAgEAgIcIBukgABAgQICLAfIECAAAECgYAAB+gmCRAgQICAAPsBAgQIECAQCAhwgG6SAAECBAgIsB8gQIAAAQKBgAAH6CYJECBAgIAA+wECBAgQIBAICHCAbpIAAQIECAiwHyBAgAABAoGAAAfoJgkQIECAgAD7AQIECBAgEAgIcIBukgABAgQIHLFxAWmhEwHPAAAAAElFTkSuQmCC</pentrails><costumes><list struct="atomic" id="2"></list></costumes><sounds><list struct="atomic" id="3"></list></sounds><variables></variables><blocks></blocks><scripts></scripts><sprites><sprite name="Sprite" idx="1" x="0" y="0" heading="90" scale="1" volume="100" pan="0" rotation="1" draggable="true" costume="0" color="80,80,80,1" pen="tip" id="8"><costumes><list struct="atomic" id="9"></list></costumes><sounds><list struct="atomic" id="10"></list></sounds><blocks></blocks><variables></variables><scripts><script x="30.294117647058826" y="156.1764705882353"><custom-block s="get the product using the combine function %l"><block var="grades"/></custom-block></script><script x="6.176470588235294" y="23.94117647058823"><block s="receiveKey"><l><option>s</option></l></block><block s="doSetVar"><l>grades</l><block s="reportNewList"><list><l>75</l><l>80</l><l>72</l><l>94</l><l>78</l><l>83</l><l>88</l><l>90</l><l>76</l><l>80</l><l>84</l><l>3266</l><l>81725</l><l>36692</l></list></block></block><custom-block s="USE BIGNUMS %b"><block s="reportBoolean"><l><bool>true</bool></l></block></custom-block></script><script x="30.88235294117647" y="190.88235294117646"><custom-block s="get the product using for loop %l"><block var="grades"/></custom-block></script><script x="29.705882352941178" y="230.88235294117646"><custom-block s="get the product using recursion %l"><block var="grades"/></custom-block></script></scripts></sprite><watcher var="grades" style="normal" x="2" y="-12" color="243,118,29" extX="136" extY="119"/></sprites></stage><hidden></hidden><headers></headers><code></code><blocks><block-definition s="get the product using the combine function %&apos;input-list&apos;" type="reporter" category="other"><header></header><code></code><translations></translations><inputs><input type="%l"></input></inputs><script><block s="doReport"><l></l></block></script></block-definition><block-definition s="get the product using for loop %&apos;input-list&apos;" type="reporter" category="other"><header></header><code></code><translations></translations><inputs><input type="%l"></input></inputs><script><block s="doDeclareVariables"><list><l>product</l></list></block><block s="doReport"><l></l></block></script></block-definition><block-definition s="get the product using recursion %&apos;input-list&apos;" type="reporter" category="other"><header></header><code></code><translations></translations><inputs><input type="%l"></input></inputs><script><block s="doDeclareVariables"><list><l>item1</l></list></block><block s="doReport"><l></l></block></script><scripts><script x="713.4068848933823" y="314.62745398039215"><custom-block s="get the product using recursion %l"><block s="reportCDR"><block var="input-list"/></block></custom-block></script></scripts></block-definition><block-definition s="USE BIGNUMS %&apos;bool&apos;" type="command" category="operators"><comment x="0" y="0" w="303.3333333333333" collapsed="false">call with True to turn on the entire Scheme numeric tower, including infinite-precision integers, exact rationals, and complex numbers; call with False to restore native JavaScript arithmetic.</comment><header></header><code></code><translations>pt:altera utilização de aritmética do Scheme para _&#xD;</translations><inputs><input type="%b"></input></inputs><script><block s="doDeclareVariables"><list><l>isDone</l></list></block><block s="doSetVar"><l>isDone</l><block s="evaluate"><block s="reportJSFunction"><list><l>useBigNums</l></list><l>var done = false;&#xD;&#xD;function initialize (callback) {&#xD;    var bigScript = document.createElement(&apos;script&apos;);&#xD;    bigScript.src = &apos;//snap.berkeley.edu/snapsource/libraries/biginteger.js&apos;;&#xD;    bigScript.onload = loadScheme;&#xD;    document.head.appendChild(bigScript);&#xD;&#xD;    function loadScheme () {&#xD;        var schemeScript = document.createElement(&apos;script&apos;);&#xD;        schemeScript.src = &apos;//snap.berkeley.edu/snapsource/libraries/schemeNumber.js&apos;;&#xD;        schemeScript.onload = finish;&#xD;        document.head.appendChild(schemeScript);&#xD;    }&#xD;&#xD;    function finish () {&#xD;        makeGlobalObject();&#xD;        callback();&#xD;    }&#xD;}&#xD;&#xD;function makeGlobalObject () {&#xD;    window.bigNumbers = {&#xD;        originalEvaluate: InputSlotMorph.prototype.evaluate,&#xD;        originalChangeVar: VariableFrame.prototype.changeVar,&#xD;        originalPrims: {&#xD;            reportSum: Process.prototype.reportSum,&#xD;            reportDifference: Process.prototype.reportDifference,&#xD;            reportProduct: Process.prototype.reportProduct,&#xD;            reportQuotient: Process.prototype.reportQuotient,&#xD;            reportPower: Process.prototype.reportPower,&#xD;            reportModulus: Process.prototype.reportModulus,&#xD;            reportRandom: Process.prototype.reportRandom,&#xD;            reportLessThan: Process.prototype.reportLessThan,&#xD;            reportGreaterThan: Process.prototype.reportGreaterThan,&#xD;            reportEquals: Process.prototype.reportEquals,&#xD;            reportIsIdentical: Process.prototype.reportIsIdentical,&#xD;            reportMonadic: Process.prototype.reportMonadic&#xD;        }&#xD;    };&#xD;}&#xD;&#xD;function loadBlocks () {&#xD;    var fn = SchemeNumber.fn;&#xD;    var originalPrims = window.bigNumbers.originalPrims;&#xD;    if (useBigNums) {&#xD;        InputSlotMorph.prototype.evaluate = function () {&#xD;            var contents = this.contents();&#xD;            if (this.constant) {&#xD;                return this.constant;&#xD;            }&#xD;            if (this.isNumeric) {&#xD;                return parseNumber(contents.text || &apos;0&apos;);&#xD;            }&#xD;            return contents.text;&#xD;        };&#xD;        VariableFrame.prototype.changeVar = function (name, delta, sender) {&#xD;            var frame = this.find(name),&#xD;                value,&#xD;                newValue;&#xD;            if (frame) {&#xD;                value = parseNumber(frame.vars[name].value);&#xD;                newValue = value !== value ? delta : value + parseNumber(delta);&#xD;                if (sender instanceof SpriteMorph &amp;&amp;&#xD;                        (frame.owner instanceof SpriteMorph) &amp;&amp;&#xD;                        (sender !== frame.owner)) {&#xD;                    sender.shadowVar(name, newValue);&#xD;                } else {&#xD;                    frame.vars[name].value = newValue;&#xD;                }&#xD;&#xD;            }&#xD;        };&#xD;        Object.assign(Process.prototype, {&#xD;            reportSum: function (a, b) {&#xD;                a = parseNumber(a);&#xD;                b = parseNumber(b);&#xD;                if (a !== a || b !== b) return NaN;&#xD;                return fn[&apos;+&apos;](a, b);&#xD;            },&#xD;            reportDifference: function (a, b) {&#xD;                a = parseNumber(a);&#xD;                b = parseNumber(b);&#xD;                if (a !== a || b !== b) return NaN;&#xD;                return fn[&apos;-&apos;](a, b);&#xD;            },&#xD;            reportProduct: function (a, b) {&#xD;                a = parseNumber(a);&#xD;                b = parseNumber(b);&#xD;                if (a !== a || b !== b) return NaN;&#xD;                return fn[&apos;*&apos;](a, b);&#xD;            },&#xD;            reportQuotient: function (a, b) {&#xD;                a = parseNumber(a);&#xD;                b = parseNumber(b);&#xD;                if (fn[&apos;=&apos;](b, &apos;0&apos;) &amp;&amp; !fn[&apos;=&apos;](a, &apos;0&apos;)) {&#xD;                      return (fn[&apos;&lt;&apos;](a, &apos;0&apos;) ? SchemeNumber(&apos;-inf.0&apos;) : SchemeNumber(&apos;+inf.0&apos;))&#xD;                };&#xD;                if (a !== a || b !== b || fn[&apos;=&apos;](b, &apos;0&apos;)) return SchemeNumber(&apos;+nan.0&apos;);&#xD;                return fn[&apos;/&apos;](a, b);&#xD;            },&#xD;            reportPower: function (a, b) {&#xD;                a = parseNumber(a);&#xD;                b = parseNumber(b);&#xD;                if (a !== a || b !== b) return NaN;&#xD;                return fn[&apos;expt&apos;](a, b);&#xD;            },&#xD;            reportModulus: function (a, b) {&#xD;                a = parseNumber(a);&#xD;                b = parseNumber(b);&#xD;                if (a !== a || b !== b) return NaN;&#xD;                var result = fn.mod(a, b);&#xD;                if (fn[&apos;&lt;&apos;](b, &apos;0&apos;) &amp;&amp; fn[&apos;&gt;&apos;](result, &apos;0&apos;)) {&#xD;                    result = fn[&apos;+&apos;](result, b);&#xD;                }&#xD;                return result;&#xD;            },&#xD;            reportRandom: function (min, max) {&#xD;                var floor = parseNumber(min),&#xD;                    ceil = parseNumber(max);&#xD;                if (floor !== floor || ceil !== ceil) return NaN;&#xD;                if (!fn[&apos;=&apos;](fn.mod(floor, &apos;1&apos;), &apos;0&apos;) || !fn[&apos;=&apos;](fn.mod(ceil, &apos;1&apos;), &apos;0&apos;)) {&#xD;                    // One of the numbers isn&apos;t whole. Include the decimal.&#xD;                    return fn[&apos;+&apos;](&#xD;                        fn[&apos;*&apos;](&#xD;                            Math.random(),&#xD;                            fn[&apos;-&apos;](ceil, floor)&#xD;                        ),&#xD;                        floor&#xD;                    );&#xD;                }&#xD;                return fn.floor(&#xD;                    fn[&apos;+&apos;](&#xD;                        fn[&apos;*&apos;](&#xD;                            Math.random(),&#xD;                            fn[&apos;+&apos;](&#xD;                                fn[&apos;-&apos;](ceil, floor),&#xD;                                &apos;1&apos;&#xD;                            )&#xD;                        ),&#xD;                        floor&#xD;                    )&#xD;                );&#xD;            },&#xD;            reportLessThan: function (a, b) {&#xD;                a = parseNumber(a);&#xD;                b = parseNumber(b);&#xD;                if (a !== a || b !== b) return NaN;&#xD;                return fn[&apos;&lt;&apos;](a, b);&#xD;            },&#xD;            reportGreaterThan: function (a, b) {&#xD;                a = parseNumber(a);&#xD;                b = parseNumber(b);&#xD;                if (a !== a || b !== b) return NaN;&#xD;                return fn[&apos;&gt;&apos;](a, b);&#xD;            },&#xD;            reportGreaterThan: function (a, b) {&#xD;                a = parseNumber(a);&#xD;                b = parseNumber(b);&#xD;                if (a !== a || b !== b) return NaN;&#xD;                return fn[&apos;&gt;&apos;](a, b);&#xD;            },&#xD;            reportEqual: function (a, b) {&#xD;                x = parseNumber(a);&#xD;                y = parseNumber(b);&#xD;                if (x !== x || y !== y) return snapEquals(a, b);&#xD;                return fn[&apos;=&apos;](x, y);&#xD;            },&#xD;            reportIsIdentical: function (a, b) {&#xD;                x = parseNumber(a);&#xD;                y = parseNumber(b);&#xD;                if (x !== x || y !== y) return originalPrims.reportIsIdentical(a, b);&#xD;                return fn[&apos;=&apos;](x, y);&#xD;            },&#xD;            reportMonadic: function (fname, n) {&#xD;                n = parseNumber(n);&#xD;                if (n !== n) return NaN;&#xD;&#xD;                switch (Process.prototype.inputOption(fname)) {&#xD;                case &apos;abs&apos;:&#xD;                    return fn.abs(n);&#xD;                case &apos;ceiling&apos;:&#xD;                    return fn.ceiling(n);&#xD;                case &apos;floor&apos;:&#xD;                    return fn.floor(n);&#xD;                case &apos;sqrt&apos;:&#xD;                    return sqrt(n);&#xD;                case &apos;sin&apos;:&#xD;                    return fn.sin(radians(n));&#xD;                case &apos;cos&apos;:&#xD;                    return fn.cos(radians(n));&#xD;                case &apos;tan&apos;:&#xD;                    return fn.tan(radians(n));&#xD;                case &apos;asin&apos;:&#xD;                    return degrees(fn.asin(n));&#xD;                case &apos;acos&apos;:&#xD;                    return degrees(fn.acos(n));&#xD;                case &apos;atan&apos;:&#xD;                    return degrees(fn.atan(n));&#xD;                case &apos;ln&apos;:&#xD;                    return fn.log(n);&#xD;                case &apos;log&apos;:&#xD;                    return fn.log(n, &apos;10&apos;);&#xD;                case &apos;e^&apos;:&#xD;                    return fn.exp(n);&#xD;                case &apos;10^&apos;:&#xD;                    return fn.expt(&apos;10&apos;, n);&#xD;                default:&#xD;                    return SchemeNumber(&apos;0&apos;);&#xD;                }&#xD;            }&#xD;        });&#xD;    } else {&#xD;        InputSlotMorph.prototype.evaluate = window.bigNumbers.originalEvaluate;&#xD;        VariableFrame.prototype.changeVar = window.bigNumbers.originalChangeVar;&#xD;        Object.assign(Process.prototype, originalPrims);&#xD;    }&#xD;    done = true;&#xD;}&#xD;&#xD;function parseNumber (n) {&#xD;    var fn = SchemeNumber.fn;&#xD;    if (!fn[&apos;number?&apos;](n)) {&#xD;        n = &apos;&apos; + n;&#xD;        try {&#xD;            return parseENotation(n) || SchemeNumber(n);&#xD;        } catch (err) {&#xD;            return NaN;&#xD;        }&#xD;    }&#xD;    return n;&#xD;}&#xD;&#xD;function parseENotation (n) {&#xD;    var fn = SchemeNumber.fn;&#xD;&#xD;    var numbers = n.match(/^(-?\d+\.?\d*|-?\.\d+)e(-?\d+)$/i);&#xD;    if (!numbers) return null;&#xD;&#xD;    var coefficient = numbers[1];&#xD;    var exponent = numbers[2];&#xD;    return fn[&apos;*&apos;](&#xD;        coefficient,&#xD;        fn.expt(&apos;10&apos;, exponent)&#xD;    );&#xD;}&#xD;&#xD;function sqrt (n) {&#xD;    var fn = SchemeNumber.fn;&#xD;&#xD;    if (!fn[&apos;exact?&apos;](n) || !fn[&apos;rational?&apos;](n) || fn[&apos;&lt;&apos;](n,&apos;0&apos;)) return fn.sqrt(n);&#xD;&#xD;    var rootNumerator = fn[&apos;exact-integer-sqrt&apos;](fn.numerator(n));&#xD;    if (!fn[&apos;=&apos;](rootNumerator[1], &apos;0&apos;)) return fn.sqrt(n);&#xD;&#xD;    var rootDenominator = fn[&apos;exact-integer-sqrt&apos;](fn.denominator(n));&#xD;    if (!fn[&apos;=&apos;](rootDenominator[1], &apos;0&apos;)) return fn.sqrt(n);&#xD;&#xD;    return fn[&apos;/&apos;](rootNumerator[0], rootDenominator[0]);&#xD;}&#xD;&#xD;function isDone () {&#xD;    return done;&#xD;}&#xD;&#xD;if (window.bigNumbers) {&#xD;    loadBlocks();&#xD;} else {&#xD;    initialize(loadBlocks);&#xD;}&#xD;&#xD;return isDone;</l></block><list><block var="bool"/></list></block></block><block s="doWaitUntil"><block s="evaluate"><block var="isDone"/><list></list></block></block></script></block-definition><block-definition s="%&apos;n&apos; !" type="reporter" category="operators"><header></header><code></code><translations></translations><inputs><input type="%n"></input></inputs><script><block s="doReport"><block s="reportIfElse"><block s="reportEquals"><block var="n"/><l>0</l></block><l>1</l><block s="reportProduct"><block var="n"/><custom-block s="%n !"><block s="reportDifference"><block var="n"/><l>1</l></block></custom-block></block></block></block></script></block-definition><block-definition s="%&apos;x&apos;" type="reporter" category="operators"><header></header><code></code><translations></translations><inputs><input type="%s"></input></inputs><script><block s="doReport"><block var="x"/></block></script></block-definition><block-definition s="Scheme number %&apos;function&apos; of %&apos;number&apos;" type="reporter" category="operators"><comment x="0" y="0" w="300" collapsed="true">Provides Scheme arithmetic functions not in JavaScript</comment><header></header><code></code><translations>pt:_ de _&#xD;</translations><inputs><input type="%s" readonly="true"><options>number?&#xD;complex?&#xD;real?&#xD;rational?&#xD;integer?&#xD;exact?&#xD;inexact?&#xD;exact&#xD;inexact&#xD;finite?&#xD;infinite?&#xD;nan?&#xD;numerator&#xD;denominator&#xD;real-part&#xD;imag-part&#xD;magnitude&#xD;angle</options></input><input type="%s"></input></inputs><script><block s="doReport"><block s="evaluate"><block s="reportJSFunction"><list><l>which</l><l>num</l></list><l>function parseNumber (n) {&#xD;    var fn = SchemeNumber.fn;&#xD;    if (!fn[&apos;number?&apos;](n)) {&#xD;        n = &apos;&apos; + n;&#xD;        try {&#xD;            return parseENotation(n) || SchemeNumber(n);&#xD;        } catch (err) {&#xD;            return NaN;&#xD;        }&#xD;    }&#xD;    return n;&#xD;}&#xD;&#xD;function parseENotation (n) {&#xD;    var fn = SchemeNumber.fn;&#xD;&#xD;    var numbers = n.match(/^(-?\d+\.?\d*|-?\.\d+)e(-?\d+)$/i);&#xD;    if (!numbers) return null;&#xD;&#xD;    var coefficient = numbers[1];&#xD;    var exponent = numbers[2];&#xD;    return fn[&apos;*&apos;](&#xD;        coefficient,&#xD;        fn.expt(&apos;10&apos;, exponent)&#xD;    );&#xD;}&#xD;var fn=SchemeNumber.fn,&#xD;      number=parseNumber(num);&#xD;&#xD;switch (which) {&#xD;  case &apos;number?&apos;:&#xD;  case &apos;complex?&apos;:&#xD;    return (fn[&apos;number?&apos;](number));&#xD;  case &apos;real?&apos;:&#xD;    return (fn[&apos;real?&apos;](number) || fn[&apos;real-valued?&apos;](number));&#xD;  case &apos;rational?&apos;:&#xD;    return (fn[&apos;rational?&apos;](number) || (fn[&apos;=&apos;](number, fn.rationalize(number, parseNumber(&apos;1.0e-5&apos;)))));&#xD;  case &apos;integer?&apos;:&#xD;    return (fn[&apos;integer?&apos;](number) || fn[&apos;integer-valued?&apos;](number));&#xD;  case &apos;exact?&apos;:&#xD;  case &apos;inexact?&apos;:&#xD;  case &apos;finite?&apos;:&#xD;  case &apos;infinite?&apos;:&#xD;  case &apos;nan?&apos;:&#xD;  case &apos;real-part&apos;:&#xD;  case &apos;imag-part&apos;:&#xD;    return (fn[which](number));&#xD;  case &apos;magnitude&apos;:&#xD;    return (fn.magnitude(number));&#xD;  case &apos;angle&apos;:&#xD;    return (fn.angle(number));&#xD;  case &apos;numerator&apos;:&#xD;    return (fn.numerator(number));&#xD;  case &apos;denominator&apos;:&#xD;    return (fn.denominator(number));&#xD;  case &apos;exact&apos;:&#xD;    return (fn.exact(number));&#xD;case &apos;inexact&apos;:&#xD;    return (fn.inexact(number));&#xD;}</l></block><list><block var="function"/><block var="number"/></list></block></block></script></block-definition></blocks><variables><variable name="grades"><list struct="atomic" id="137">75,80,72,94,78,83,88,90,76,80,84,3266,81725,36692</list></variable></variables></project><media name="dbitko-2020-01-07-iteration-practice-3" app="Snap! 5.4, http://snap.berkeley.edu" version="1"></media></snapdata>