今日算法:蓝桥杯基础题之“门牌制作”

你好同学,我是沐爸,欢迎点赞、收藏、评论和关注!个人知乎

今日算法第二题,如何制作门牌号,一起看看吧。

问题描述

小蓝要为一条街的住户制作门牌号。

这条街一共有 2024 位住户,门牌号从 1 到 2024 编号。

小蓝制作门牌的方法是先制作 0 到 9 这几个数字字符,最后根据需要将字符粘贴到门牌上,例如门牌 1017 需要依次粘贴字符 1、0、1、7,即需要 1 个字符 0,2 个字符 1,1 个字符 7。

请问要制作所有的 1 到 2024 号门牌,总共需要多少个字符 2?

JavaScript 题解代码

为了解决这个问题,我们可以编写一个JavaScript函数,该函数遍历从1到2024的所有数字,并计算每个数字中字符'2'出现的次数。然后,将所有数字中'2'的出现次数相加,得到最终结果。

下面是一个实现这个逻辑的JavaScript函数:

javascript 复制代码
function getTimes(maxNumber, n) {
  let count = 0;
  for (let i = 1; i <= maxNumber; i++) {
    // 将数字转换为字符串,以便逐个字符检查
    const str = i.toString();
    // 遍历字符串中的每个字符
    for (let j = 0; j < str.length; j++) {
      // 如果字符是'n',则增加计数器
      if (str[j] === n.toString()) {
        count++;
      }
    }
  }
  return count;
}

console.log(getTimes(2024, 2)); // 633

这个函数首先定义了一个计数器count,用于记录字符'2'的总数。然后,它使用一个for循环遍历从1到maxNumber(在这个例子中是2024)的所有数字。对于每个数字,它首先将其转换为字符串,然后遍历字符串中的每个字符。如果字符是'2',则增加计数器。最后,函数返回计数器的值,即所有数字中字符'2'的总数。

好了,分享结束,谢谢点赞,下期再见

参考:https://edu.csdn.net/skill/practice/algorithm-b7a24f3dc0894922b58174677d4a1e4a/2259?language=algorithm&materialId=19513

相关推荐
有梦想的咸鱼还是咸鱼吗几秒前
前端必会|防抖与节流从原理到实战,解决90%高频事件卡顿问题
前端
用户5757303346241 分钟前
深入 JavaScript 内存机制:从栈与堆到闭包的底层原理
javascript
阿诺木3 分钟前
Node.js 局域网设备发现:mDNS、UDP 广播和子网扫描
前端
盐焗乳鸽还要砂锅3 分钟前
亲手造一只有灵魂的 AI 小龙虾是种什么体验?
前端·llm·agent
YimWu4 分钟前
Opencode 核心设计-Session会话机制
前端·agent·ai编程
Mintopia8 分钟前
诗词如何影响人:从认知机制到可落地的文本分析技术路线
前端·代码规范
WaywardOne13 分钟前
iOS必看!Deepseek给的Runtime实现原理,通俗易懂~
前端·面试
小码哥_常17 分钟前
惊!Kotlin集合,你可能只用了40%?
前端
苏纪云22 分钟前
蓝桥杯知识点——day2
数据结构·算法·蓝桥杯
Wect23 分钟前
LeetCode 52. N 皇后 II:回溯算法高效求解
前端·算法·typescript