数组习题

<script>
        // 1.从键盘接受10个整数,求出其中的最大值和最小值。

        // var maxNum = -Infinity;      //最大值假设为负无穷
        // var minNum = Infinity;       //同上,之不过最小值设假设为正无穷
        // 遍历数组
        // for (var i = 0; i < 10; i++) {
        //     var num = +prompt("请输入第" + (i + 1) + "个数");
                // 输入的数和最大值比较,如果输入的数大于最大值就赋值给最小值
        //     if (num > maxNum) {
        //         maxNum = num;
        //     }
                // 输入的数和最小值比较,如果输入的数小于最小值就赋值给最小值
        //     if (num < minNum) {
        //         minNum = num;
        //     }
        // }
        // console.log("最大值:" + maxNum);
        // console.log("最小值:" + minNum);



        // 2.输入10个数,保存在一个数组中,在数组中查找某个数字,给出是否找到信息,如果找到了输出该数在数组中所处的位置,如果找不到输出“找不到”

        // 设空数组
        // var arr = [];
        // 遍历空数组
        // for (var i = 0; i < 10; i++) {
        //     var inpNum = +prompt("请输入第"+(i+1)+"个数");
        //     arr[arr.length] = inpNum;
        // }

        // var findNum = +prompt("请输入要查找的数");
        // 假设要查找的数为-1,就为找不到否则就打印出该书在数组中的下标
        // if(arr.indexOf(findNum) == -1){
        //     alert("找不到");
        // }else{
        //     console.log(arr);
        //     alert("该数在数组的下标是"+arr.indexOf(findNum))
        // }

        // 3.如果一个数组保存元素是有序的(从大到小),向这个数组中插入一个数,使得插入后的数组元素仍然保持有序。
        // var arr = [17,15,13,11,9,7,5,3,1];
        // console.log(arr);
        // var num = +prompt("请输入要插入的数");
        // for (var i = 0; i < arr.length; i++) {
        //     if (num >= arr[i]) {
        //         arr.splice(i,0,num);
        //         break;
        //     }
        // }
        // console.log(arr);


        // 4.将一个数组中的元素逆序输出,即第一个元素和最后一个元素交换,第二个数与倒数第二元素交换…..,例如:原数组为:9     2 5 7  8,逆序后的数组为:8  7  5 2 9
        // var arr = [1,2,3,4,5,6,7,8,9];
        // console.log(arr.reverse());

            // 第二种
            // var arr1 = [3, 6, 1, 8, 5];
            // var num = arr.length;
            // 这里的用法和冒泡排序差不多
            // for (var i = 0; i < num / 2; i++) {
            //     var temp = arr1[i];
            //     var j = i + 1;
            //     arr1[i] = arr1[num - j];
            //     arr1[num - j] = temp
            // }
            // console.log(arr1);

        // 5.顾客从超市采购了10件商品,编写一个程序,用于接受每件商品的价格,计算应付的总金额。并分别打印出各个商品的价格以及应付的总金额的小票。
        // console.log("==========商品小票==========");
        // var sumTotal = 0;
        // for (var i = 0; i < 10; i++) {
        //     var goodsPrice = +prompt("请输入第" + (i + 1) + "件商品价格");
        //     console.log("第"+(i+1)+"件商品的价格:"+goodsPrice+"元");    
        //     sumTotal+= goodsPrice;
        // }

        // console.log("应付的总金额:"+sumTotal+"元");
        // console.log("===========================");


        // 6.编写一个程序,用于产生20个0 - 10之间的随机数,将这20个随机数存入数组,并通过函数统计这些随机数中某个数出现的次数

        var rNumFunc = function() {
            var arr = [];
            for (var i = 0; i < 20; i++) { //生成随机数数组
                arr[i] = Math.floor(Math.random() * 10);
            }
            console.log(arr);
            for (var i = 0; i < arr.length; i++) { //外层循环需要判断的数
                var index = 0; //查找的起始下标
                for (var j = 0, count = 0; j < arr.length; j++) { //内层循环数组统计出现的次数
                    if (arr.indexOf(arr[i], index) != -1) {
                        count++; //出现的次数
                        index = arr.indexOf(arr[i], index) + 1;
                    }
                }
                if (arr.indexOf(arr[i]) == i) { //输出去重
                    console.log("随机数" + arr[i] + "出现了" + count + "次");
                }
            }
        }
        rNumFunc();
        // 7.输入数组,最大的与第一个元素交换,最小的与最后一个元素交换,输出数组。
        // var arr = [];
        // for (var i = 0; i < 5; i++) {
        //     var num = +prompt("请输入第" + (i + 1) + "个数");
        //     arr[arr.length] = num;
        // }
        // console.log(arr);
        // //冒泡排序
        // for (var i = 0; i < arr.length; i++) {          //外层循环每个数
        //     for (var j = 0; j < arr.length-1-i; j++) {  //内层循环剩余的数
        //         if (arr[j] < arr[j+1]) {                //判断相邻的数排序
        //             var temp = arr[j+1];
        //             arr[j+1] = arr[j];
        //             arr[j] = temp;
        //         }
        //     }
        // }
        // console.log(arr);
        // 8.定义一个用户数组,数组的每一项是一个用户对象,用户对象中包括账号和密码,随意初始化一些对象放入数组中。
        // 然后提示用户输入账号和密码,判断是否登录成功。
        // 先定义数组
            // var arr = [
            //     {'userName' : '张三', 'pwd':123},
            //     {'userName' : 'Linda', 'pwd':456},
            //     {'userName' : 'Mary', 'pwd':789}
            // ]
            // // 2.获取输入的数据
            // var name = prompt('请输入账号');
            // var pwd = prompt('请输入密码');

            // // 3.数组的遍历
            // for (var i = 0; i < arr.length; i++) {
            //     if (name == arr[i].userName && pwd == arr[i].pwd) {
            //         console.log('登录成功');
            //     }else{
            //         console.log('登录不成功');
            //     }            
            // }
    </script>

 

posted @ 2020-07-26 16:18  花开荼蘼Ⅴ彼岸未归  阅读(200)  评论(0编辑  收藏  举报