• 个人作业1小学四则运算生成


    题目

    除了整数以外,还要支持真分数的四则运算,真分数的运算,例如:1/6 + 1/8 = 7/24
    运算符为 +, −, ×, ÷
    并且要求能处理用户的输入,并判断对错,打分统计正确率。
    要求能处理用户输入的真分数, 如 1/2, 5/12 等
    使用 -n 参数控制生成题目的个数,例如执行下面命令将生成10个题目
    Myapp.exe -n 10
    

    需求分析

    根据题目要求,需要有如下基本功能

    • 自动生成四则运算题目
    • 用户可以填写答案
    • 程序可以判断对错并生成正确答案
    • 程序可以自定义生成题目范围和题目数量
      拓展
    • 基于web实现如上功能,可以更为直观的用户体验

    程序设计与实现

    用javascript封装了如下函数,便于修正

    • getNum() 根据输入获得生成随机数的范围并返回随机生成数
            //@getNum 根据输入获得生成随机数的范围
            //@result 随机获得1~最大范围以内的随机整数
            function getNum() {
                var max = document.getElementById('test_range')['value'];
                var range = max - 1;
                var random = Math.random();
                var result = Math.round(random * range) + 1;
                return result;
            }
    
    • getOperators() 随机获得运算符
            //@getOperators 随机获得四则运算符
            //@result 获得得运算符('+','-','*','/')
            function getOperators() {
                var Operators = ['+', '-', '*', '/'];
                var n = parseInt(4 * Math.random());
                var result = Operators[n];
                return result;
            }
    
    • getFraction() 根据随机数生成一个分式
            function getFraction(num_a, num_b) {
                var result = 1;
                if (num_a == num_b) {
                    result = 1;
                } else if (num_a > num_b) {
                    if (num_a % num_b == 0) {
                        result = num_a / num_b;
                    } else {
                        result = num_a + "/" + num_b;
                    }
                } else {
                    result = num_a + "/" + num_b;
                }
                return result;
            }
    
    • simplify()化简
            /*   @simplify 化简 辗转相除法求最大公因数
             *   @mol 分子
             *   @den 分母
             */
            function simplify(mol, den) {
                var temp;
                var Mol = mol;
                var Den = den;
                while (den) {
                    temp = mol % den;
                    mol = den;
                    den = temp;
                }
                var temp = mol;
                if (temp != 0) {
                    mol = Mol / temp;
                    den = Den / temp;
                    if (den == 1) {
                        return mol;
                    } else {
                        return mol + "/" + den;
                    }
                }
            }
    
    • getQuiz() 生成并在dom输出算式
            /*  @getQuiz 生成算式  
             *  @Fra_a,@Fra_b,@Fra_c,@Fra_d 分子分母,用来生成分式
             *  @operator 运算符
             */
            function getQuiz(Fra_a, Fra_b, Fra_c, Fra_d, operator) {
                var num_a = getFraction(Fra_a, Fra_b);
                var num_b = getFraction(Fra_c, Fra_d);
                var na = parseInt(Fra_a) / parseInt(Fra_b);
                var nb = parseInt(Fra_c) / parseInt(Fra_d);
                var temp = 0;
                document.getElementById('test_body').innerHTML += num_a;
                document.getElementById('test_body').innerHTML += operator;
                document.getElementById('test_body').innerHTML += num_b;
                var answer = 0;
                switch (operator) {
                    case '+':
                        var mol = (parseInt(Fra_a) * parseInt(Fra_d)) + (parseInt(Fra_c) * parseInt(Fra_b));
                        var den = parseInt(Fra_b) * parseInt(Fra_d);
                        answer = simplify(mol, den);
                        break;
                    case '-':
                        var mol = (parseInt(Fra_a) * parseInt(Fra_d)) - (parseInt(Fra_c) * parseInt(Fra_b));
                        var den = parseInt(Fra_b) * parseInt(Fra_d);
                        answer = simplify(mol, den);
                        break;
                    case '×':
                        var mol = parseInt(Fra_a) * parseInt(Fra_c);
                        var den = parseInt(Fra_b) * parseInt(Fra_d);
                        answer = simplify(mol, den);
                        break;
                    case '÷':
                        var mol = parseInt(Fra_a) * parseInt(Fra_d);
                        var den = parseInt(Fra_b) * parseInt(Fra_c);
                        answer = simplify(mol, den);
                        break;
                }
                return answer;
            }
    
    • create_test() 生成点击事件绑定函数
           //@create_test 生成代码,点击事件绑定函数
            function create_test() {
                //var a = getFraction(24, 12);
                //document.getElementById('box').innerHTML = a + '</br>';
                document.getElementById('test_body').innerHTML = '';
                var test_num = document.getElementById('test_num')['value'];
                for (var i = 0; i < test_num; i++) {
                    document.getElementById('test_body').innerHTML += "第" + (i + 1) + "题:";
                    /*var Num_a = getFraction(getNum(), getNum());
                    var Num_b = getFraction(getNum(), getNum());*/
                    var Operator = getOperators();
                    if (Operator == '/') {
                        Operator = '÷';
                    } else if (Operator == '*') {
                        Operator = '×';
                    }
                    answer[i] = getQuiz(getNum(), getNum(), getNum(), getNum(), Operator);
                    document.getElementById('test_body').innerHTML += '=' + "<input class='test_in' type='text' style='50px;'/>";
                    document.getElementById('test_body').innerHTML += '</br>';
                }
            }
    
    • create_answer() 生成答案点击事件绑定函数
            //@Answer 从dom获取到的答案(填写答案)
            //@answer 通过函数生成的答案(正确答案)
            function create_answer() {
                document.getElementById('answer').innerHTML = "";
                document.getElementById('judge').innerHTML = "";
                //输出正确答案
                for (var k in answer) {
                    document.getElementById('answer').innerHTML += "第" + (parseInt(k) + 1) + "题:";
                    document.getElementById('answer').innerHTML += answer[k] + '&nbsp';
                    if ((parseInt(k) + 1) % 5 == 0) {
                        document.getElementById('answer').innerHTML += '</br>'
                    }
                    var Answer = document.getElementsByClassName('test_in')[k]['value'];
                    //判断对错
                    if (Answer != answer[k]) {
                        document.getElementById('judge').innerHTML += "第" + (parseInt(k) + 1) + "题回答错误&nbsp";
                    }
                }
            }
    
    

    html代码如下

        <body>
                <div class="btn_create">
                    <div>
                        <span>请输入题目最大范围:</span>
                        <input type="text" class="test_range" id="test_range" value="30" />
                    </div>
                    <div>
                        <span>请输入要生成的题目数:</span>
                        <input type="text" class="num" id="test_num" value="30" />
                    </div>
                    <input type="button" name="start" value="点击开始生成题目" onclick="create_test()">
                </div>
                <div class="box" id="box" style="font-size: 20px;line-height: 27px;">
                    <form id="test_body" class="test_body">
                    </form>
                </div>
    
                <div class="btn_judge"><input type="button" value="判断并生成答案" onclick="create_answer()" /></div>
                <div class="answer" id="answer" style="font-size: 20px;line-height: 27px;">
                </div>
                <div id="judge" style="color:#ff0000"></div>
            </body>
    

    程序测试

    • 程序开始页面
    • 点击生成题目
    • 输入答案并判断结果

    自评

    程序并不完善,生成范围以及题目数量较大时会出现卡顿,反应时间较长。代码规范程度也不完善,某些变量名不够完善。纯前端实现这个程序有些偷懒,并不能存储测试结果,只能即使的反应测试情况,如果加入php和ajax程序功能会更加完善一些。

    psp

    代码地址

    https://coding.net/u/augur_g/p/Individual-work/git/blob/master/四则运算.html

  • 相关阅读:
    Page.EnableViewStateMac 属性
    ASP.NET2.0权限/角色管理表aspnet_Membership解析(转)
    Request.ServerVariables(HTTP_REFERER)
    对象不能从DBNull 转换为其他类型
    ASP.NET角色管理配置
    TextBox保存的文本在Label中显示
    SET NOCOUNT ON
    浅论ViewState及其与Session的关系(转)
    ASP.NET2.0权限/角色管理表aspnet_Applications解析(转)
    动态编辑控件宽高
  • 原文地址:https://www.cnblogs.com/augurG/p/6498653.html
Copyright © 2020-2023  润新知