javaScript数组-(进阶算法)-计算正整数各个位数上的数字之和

基础

javaScript数组-(进阶算法)-计算正整数各个位数上的数字之和

javascript 复制代码
function sumDigits(num) {
    // 检查输入是否为数字,增强代码健壮性
    if (typeof num !== 'number' || isNaN(num) || !isFinite(num)) {
        throw new Error('Input must be a finite number');
    }

    let sum = 0;
    let temp = num;
    
    // 使用循环来相加数字的每一位
    while(temp != 0) {
        // 使用let声明局部变量temp,避免全局污染
        sum += temp % 10;
        temp = Math.floor(temp / 10);
    }

    // 在函数末尾返回sum,确保函数有返回值
    return sum;
}

// 调用函数并打印结果
console.log(sumDigits(385)); // 输出16

进阶

直到结果不再大于9(个位数)为止。然后返回最后得到的这个结果。递归

javascript 复制代码
/**
 * 该函数接受一个数字作为参数,反复将该数字的各个位上的数字相加,
 * 直到结果不再大于9(个位数)为止。然后返回最后得到的这个结果。
 * 
 * @param {number} num - 输入的数字。
 * @return {number} 返回经过连续相加操作后的最终结果。
 */
function fun(num){
    let sum = 0; // 用于存储各位数字相加的累加和
    let temp = num; // 临时变量用于处理数字的每一位
    while(temp != 0){
        sum += temp % 10; // 将当前数字的个位数加到sum上
        temp = Math.floor(temp / 10); // 将当前数字除以10,去掉个位数
    }
    // 如果sum大于9,则递归调用fun函数,传入sum作为新的num
    if(sum>9){
        return fun(sum);
    }else{
        return sum // 当sum不再大于9时,返回sum
    }
}

let result = fun(385); // 调用fun函数,传入385
console.log(result); // 输出结果
相关推荐
正在学习前端的---小方同学10 分钟前
vue-easy-tree树状结构
前端·javascript·vue.js
万粉变现经纪人1 小时前
如何解决 pip install -r requirements.txt 私有索引未设为 trusted-host 导致拒绝 问题
开发语言·python·scrapy·flask·beautifulsoup·pandas·pip
qq_479875431 小时前
C++ std::Set<std::pair>
开发语言·c++
云知谷4 小时前
【C++基本功】C++适合做什么,哪些领域适合哪些领域不适合?
c语言·开发语言·c++·人工智能·团队开发
键盘不能没有CV键4 小时前
【图片处理】✈️HTML转图片字体异常处理
前端·javascript·html
电子_咸鱼4 小时前
LeetCode——Hot 100【电话号码的字母组合】
数据结构·算法·leetcode·链表·职场和发展·贪心算法·深度优先
仰泳的熊猫4 小时前
LeetCode:785. 判断二分图
数据结构·c++·算法·leetcode
yantuguiguziPGJ4 小时前
WPF 联合 Web 开发调试流程梳理(基于 Microsoft.Web.WebView2)
前端·microsoft·wpf
rit84324994 小时前
基于MATLAB实现基于距离的离群点检测算法
人工智能·算法·matlab
l1t5 小时前
DeepSeek辅助利用搬移底层xml实现快速编辑xlsx文件的python程序
xml·开发语言·python·xlsx