函数的概念

函数的概念

为什么需要用函数?

首先看一下输出100以内所有素数问题的解决方案。

方案一:循环的嵌套

for(var n = 2;n < 100;n++){
    var m = Math.ceil(Math.sqrt(n));//根据数学相关定理,查找范围可缩小至[2,sqrt(n)]
    
var found = false;//设置一个找到因子的标记
    
for(var i = 2;i <= m;i++){
        if(n % i == 0){
            found = true;
            break;//找到则提前结束
        
}
    }
    if(!found){
        document.write(n + "是素数" + "</br>");
    }
}

这种解决方案程序比较复杂,阅读也比较困难,需要比较高超的技术


方案二:使用函数

for(var n = 2;n <= 100;n++){
    if(isPrime(n)){
        document.write(n + "</br>");
    }
}

function isPrime(n){
    var m = Math.ceil(Math.sqrt(n));//根据数学相关定理,查找范围可缩小至[2,sqrt(n)]
    
for(var i = 2;i <= m;i++){
        if(n % i == 0){
            return false;
        }
    }
    return true;
}

这种解决方案是将一个比较复杂的问题分解为两个较为简单的问题去解决,是用“量”去克服“难”和“大”的问题。

这种解决方案给我们提供了一个解决规模大、难度高的解决思路:用它分解为多个规模相对较小、难度相对较低的问题去解决,如果分解后的问题仍然规模大或者难度高,可以按照这个思路一直分解下去,直到分解后的问题足够小、简单。归纳起来就是“大事化小”。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值