node js 下查找数组最大最小值 时间复杂度 1.5N 思路来自编程之美

本文介绍使用Node.js进行基本的输入输出操作,并通过示例代码展示了如何处理数组,包括利用map和条件语句找出最大最小值。此外,还介绍了array.forEach和array.map等方法不会改变原数组的特点。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

主要是熟悉一下node输入输出,以及array.forEach 和 array.map 都不会直接改变原数组。还有三目运算符 : 两侧必须是单语句。

const readline = require('readline')
const rl = readline.createInterface({
    input:process.stdin,
    output:process.stdout
})
var input
rl.on('line',function(line){
        var arr = line.trim().split(' ')
        arr = arr.map(function (item) {
            return +item
        })
        switch (arr.length){
            case 0: console.log('no item empty array');break;
            case 1: console.log([arr[0],arr[0]]);break;
            case 2: arr[0]>arr[1]? console.log([arr[0],arr[1]]):console.log([arr[1],arr[0]]);break;
            default:
            var min, max;
            if (arr[0]>arr[1]){
                min = arr[1],max= arr[0] 
            }
            else {
                min = arr[0],max= arr[1]
            }
            for( var i = 2 ; i < arr.length ; i+=2){
                if(arr[i]){
                    if(arr[i+1]){
                        if (arr[i] > arr [i+1]){
                            max = arr[i] > max ? arr[i] : max
                            min = arr[i+1] < min ? arr[i+1] : min
                        }
                        else{
                            max = arr[i+1] > max ? arr[i+1] : max
                            min = arr[i] < min ? arr[i] : min
                        }
                    }
                    else {
                        max = arr[i] > max ? arr[i] : max
                        min = arr[i] < min ? arr[i] : min
                    }
                }
            }//end of loop
            console.log([max,min])
        }

})

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值