JavaScript第五章作业

 // 1.重复数 
        // 例题:有1、2、3、4个数字,能组成多少个互不相同且无重复数字的三位数?都是多少?
        var arr = ['1', '2', '3', '4'];
        var ars = [];

        // 拿出来三个数字
        for (var i = 0; i < 4; i++) {
            for (var k = 0; k < 3; k++) {
                for (var j = 0; j < 4; j++) {
                    // 减少自己和自己重复   相等跳过循环
                    if (i == k || i == j || k == j) {
                        continue
                    }
                    ars.push(arr[i] + arr[k] + arr[j])
                    ars.push(arr[j] + arr[i] + arr[k])
                }
            }
        }

        // 去重
        function func(arr) {
            for (var i = 0; i <= arr.length; i++) {
                for (var j = i + 1; j < arr.length; j++) {
                    if (arr[i] == arr[j]) {
                        arr.splice([j], 1)
                        j--
                    }
                }
            }
        }
        func(ars)

        // 重新排序 从小到大
        ars.sort(function (a, b) {
            return a - b;
        })

        console.log(ars);

素数

 // 2.素数
        // 例题:判断101 - 200之间有多少个素数,并输出所有素数(只能被1和它本身整除的自然数为素数)
        var ar = 0;
        for (var i = 101; i < 200; i++) {
            for (var k = 2; k < i; k++) {
                if (i % k == 0) {
                    break
                }
            }
            if (k >= i) {
                console.log(i);
            }
        }

水仙花数

  // 3.水仙花数
        // 例题:打印出所有的水仙花数,所谓“水仙花数”是指一个三位数,其各位数字立方和等于该数本身。例如:153是一个“水仙花数”,因为153=1的三次方+5的三次方+3的三次方。
        for (var i = 100; i < 1000; i++) {
            var bai = parseInt(i / 100);
            var shiwei = parseInt(i % 100 / 10);
            var gewei = parseInt(i % 10);

            var he = bai * bai * bai + shiwei * shiwei * shiwei + gewei * gewei * gewei;
            if (he == i) {
                console.log('水仙花数:'+i);
            }
        }

因式分解

// 题目: 将一个正整数分解质因数.例如:输入90,打印出90=2*3*3*5
// 首先判断是不是质数
function primeCheck(n) {
  for (var i = 2; i < n; i++) {
    if (n % i == 0) {
      return false;
    }
  }
  return true;
}
 
function prime(k) {
  var str = '';
  for (var t = 2; t < k; t++) {
    if (k % t == 0) { //遍历筛选出能被整除且是质数的数
      if (primeCheck(t)) {
        // 字符串拼接
        str += t + '*';
        k /= t;
        t = 1;
      }
 
    }
  }
  str += k //最后一个必然是质数,必然不会被小于它的数整除
  return str;
}
 
var a = prime(90);
console.log(a); //2*3*3*5

求任意两个正整数的最大公约数(GCD)和最小公倍数(LCM)


        function max_gy(a,b){
            while (true){
                var yu=a%b;
                if (yu==0){
                    return b;
                }
                a=b;
                b=yu;
            }
        }
        function min_gb(a,b){
            return a*b/max_gy(a,b);
        }
        
        var a=Number(prompt("请输入第一个值:"));
        var b=Number(prompt("请输入第二个值:"));
        document.write(a+"和"+b+"的最大公约数为:"+max_gy(a,b));
        document.write("<br>");
        document.write(a+"和"+b+"的最小公倍数为:"+min_gb(a,b));

最大差值

   // 7.数组最大差值
        var arr = [12, 213, 14, 13, 52, 75]
        arr.sort(function (a, b) {
            return a - b
        })
        var ar = arr.length - 1;
        var nub = arr[ar] - arr[0];
        console.log(nub);

数组去重

function unique(arr) {
    if (!Array.isArray(arr)) {
        console.log('type error!')
        return
    }
    let res = []
    for (let i = 0; i < arr.length; i++) {
        if (res.indexOf(arr[i]) === -1) {
            res.push(arr[i])
        }
    }
    return res
}

冒泡排序

//创建一个变量作为临时存储数据的地方
const arr = [29,10,14,37,15];
//创建一个bubbleSort函数用来执行冒泡排序
function bubbleSort(arr){
    let temp;//临时交换变量
    //创建一个外围循环来确定要排序多少轮,
    //同时保证下一轮不会重复对比最后一个元素,
    //所以不用遍历到最后一个元素
    for(let i = 0; i < arr.length - 1; i++){
        //镶嵌循环则要做两两元素的比较与缩小每轮比较的目标数量
        for(let j =0; j < arr.length - 1 - i; j++){
            if (arr[j] > arr[j+1]){
                temp=arr[j];
                arr[j]=arr[j+1];
                arr[j+1]=temp;
            }
        }
    }
    return arr;
}

console.log(bubbleSort(arr));

闰年

// 11. 输出1900年至2100年中的所有闰年(普通年能被4整除且不能被100整除的为闰年)
        for (var i = 1900; i < 2100; i++) {
            if (i % 4 == 0 && i % 100 != 0) {
                console.log(i);
            }
        }

每个位上面的数字

  // 13. 取出四位数中的各个位上的数字   1234
        // var str = prompt('请输入四位数');
        var nub = 1234;
        var str = nub.toString();
        var arr = str.split('');
        console.log('千位:' + arr[0], '百位' + arr[1], '十位' + arr[2], '个位' + arr[3]);

菱形

  // 14. 用星号输出菱形
        var str = '';
        for (var i = 1; i <= 10; i++) {
            // 每次的空格数从10-1
            for (var k = 1; k <= 10 - i; k++) {
                str += ' ';
            }
            // 每次的星星数从加上1
            for (var j = 1; j <= i - 1; j++) {
                str += '☆'
            }
            str += '\n'
        }
        // 每次空格加1
        for (var i = 1; i < 10; i++) {
            for (var k = 1; k <= i; k++) {
                str += ' ';
            }
            // 每次星星从10开始-1
            for (var j = 1; j < 10-1 *i; j++) {
                str += '☆'
            }
            str += '\n'
        }
        console.log(str);

猴子吃桃

  // 15.    猴子吃桃问题
        // 猴子吃桃子问题:猴子第一天摘下N个桃子,当时就吃了一半,还不过瘾,就又吃了一个。第二天又将剩下的桃子吃掉一半,
        // 又多吃了一个。以后每天都吃前一天剩下的一半零一个,到第10天在想吃的时候就剩一个桃子了。求第一天共摘下来多少个桃子?
        var n = 1;
        for (var i = 1; i < 10; i++) {
            n = (n + 1) * 2
        }
        console.log('第一天一共摘下来:' + n+'桃子');

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值