• Javascript 小练习



    --------------------------要收获别人五年才能收获的东西,你就要做好准备,遭受别人五人所遭受的坎坷”
    // -------------------------------*******************-------------------------------

    /*写一个函数,功能实现是告知你所选定的小动物的叫声*/

    // function vioce(animal) {
    // switch (animal){
    // case "dog":
    // document.write("wang!wang!");
    // return;
    // case "cat":
    // document.write("miao!miao!");
    // return;
    // case "fish":
    // document.write("O~O~O~!");
    // return;
    // default:
    // document.write("卡哇伊拉塞!");
    // return
    // }
    // }

    /*在网页console里执行vioce("dog")*/
    //vioce("dog")

    // -------------------------------*******************-------------------------------

    /*写一个函数,实现加法计数器*/

    // function jia(a,b) {
    // // document.write(a+b)
    // // return a+b
    // }

    //add(5,7)


    // -------------------------------*******************-------------------------------

    // 定义一组函数 输入数字 逆转并输出汉字形式

    // function reverse() {
    // var num = window.prompt('input');
    // var str = '';
    // for (var i = num.length - 1; i >= 0; i--) {
    // str += transfer(num[i]);
    // }
    // document.write(str);
    // }
    //
    //
    // function transfer(content) {
    // switch (content) {
    // case "1":
    // return '壹';
    // case "2":
    // return '俩';
    // case "3":
    // return '仨';
    // }
    // }

    // -------------------------------*******************-------------------------------
    //定义一个函数 实现一个阶乘算法 (找规律,找出口) (递归)

    function mul(n) {
    //思路 先找规律 求一个数的阶乘 就是 n*(n-1)
    // 找出口 当n=1 时 就知道结果
    if (n == 1) {
    return 1;
    }
    return n * mul(n - 1)
    }
    mul(5)

    // -------------------------------*******************-------------------------------
    //定义一个函数 实现斐波那契数列

    <script type="text/javascript">
    function fibonacci(n) {
    var one = 1;    
    var two = 1;    
    for(var i = 3; i <= n; i++) {    //此处代码重点部分,用three累加前两个数的和,也是斐波那契数列的精髓所在。
    var three = one + two;      
    one = two;      
    two = three;      

    }
    if (n==1||n==2) {    //判断n==1或2的情况下返回undefined
    return one;
    }
    return three;       //最后返回three
    }
    console.log(fibonacci(2));
    </script>





    // -------------------------------*******************-------------------------------
    [递归实现--斐波那契数列]

    function box(m){
    if(m==1||m==2){
    return 1;
    }
    8 return box(m-1)+box(m-2);    //除去1和2的两种情况,递归斐波那契数列一行代码就能搞定,但是递归性能是大大不如函数的。
    }
    alert(box(2));








    // -------------------------------*******************-------------------------------
    // 要求输入一串低于10位的数字 纯输出这穿数字的中文大写


    function convertCurrency(money) {
    //汉字的数字
    var cnNums = new Array('零', '壹', '贰', '叁', '肆', '伍', '陆', '柒', '捌', '玖');
    //基本单位
    var cnIntRadice = new Array('', '拾', '佰', '仟');
    //对应整数部分扩展单位
    var cnIntUnits = new Array('', '万', '亿', '兆');
    //对应小数部分单位
    var cnDecUnits = new Array('角', '分', '毫', '厘');
    //整数金额时后面跟的字符
    var cnInteger = '整';
    //整型完以后的单位
    var cnIntLast = '元';
    //最大处理的数字
    var maxNum = 999999999999999.9999;
    //金额整数部分
    var integerNum;
    //金额小数部分
    var decimalNum;
    //输出的中文金额字符串
    var chineseStr = '';
    //分离金额后用的数组,预定义
    var parts;
    if (money == '') { return ''; }
    money = parseFloat(money);
    if (money >= maxNum) {
    //超出最大处理数字
    return '';
    }
    if (money == 0) {
    chineseStr = cnNums[0] + cnIntLast + cnInteger;
    return chineseStr;
    }
    //转换为字符串
    money = money.toString();
    if (money.indexOf('.') == -1) {
    integerNum = money;
    decimalNum = '';
    } else {
    parts = money.split('.');
    integerNum = parts[0];
    decimalNum = parts[1].substr(0, 4);
    }
    //获取整型部分转换
    if (parseInt(integerNum, 10) > 0) {
    var zeroCount = 0;
    var IntLen = integerNum.length;
    for (var i = 0; i < IntLen; i++) {
    var n = integerNum.substr(i, 1);
    var p = IntLen - i - 1;
    var q = p / 4;
    var m = p % 4;
    if (n == '0') {
    zeroCount++;
    } else {
    if (zeroCount > 0) {
    chineseStr += cnNums[0];
    }
    //归零
    zeroCount = 0;
    chineseStr += cnNums[parseInt(n)] + cnIntRadice[m];
    }
    if (m == 0 && zeroCount < 4) {
    chineseStr += cnIntUnits[q];
    }
    }
    chineseStr += cnIntLast;
    }
    //小数部分
    if (decimalNum != '') {
    var decLen = decimalNum.length;
    for (var i = 0; i < decLen; i++) {
    var n = decimalNum.substr(i, 1);
    if (n != '0') {
    chineseStr += cnNums[Number(n)] + cnDecUnits[i];
    }
    }
    }
    if (chineseStr == '') {
    chineseStr += cnNums[0] + cnIntLast + cnInteger;
    } else if (decimalNum == '') {
    chineseStr += cnInteger;
    }
    return chineseStr;
    }


























  • 相关阅读:
    Spring AOP里的静态代理和动态代理,你真的了解嘛?
    redis的三种启动方式
    Linux MySQL分库分表之Mycat
    Linux 之Mycat搭建报错 java.net.MalformedURLException: Local host name unknown: java.net.UnknownHostException
    Linux MySQL Proxy 读写分离
    Linux MySQL集群搭建之主从复制
    Linux 虚拟机详细安装MySQL
    MySQL 性能优化细节
    MySQL 性能优化之慢查询
    MySQL事务处理
  • 原文地址:https://www.cnblogs.com/dealdwong2018/p/10158901.html
Copyright © 2020-2023  润新知