华为OD --- 靠谱的车

华为OD --- 靠谱的车

题目

OJ用例

测试用例case

独立实现

思路

独立实现的思路比较简单,直接建一个长度为N的数组,然后找出index中不包含4的项数即可

源码

js 复制代码
const rl = require("readline").createInterface({ input: process.stdin });
var iter = rl[Symbol.asyncIterator]();
const readline = async () => (await iter.next()).value;

void (async function () {
    // 输入实际付费的钱
    const payCount = Number(await readline());
    // const payCountList = new Array(payCount).fill(1)
    let numberIn4 = 0

    for (let i = 1; i <= payCount; i++) {

        if(`${i}`.includes(4)){
            numberIn4 ++
        }
    }

    console.log(payCount - numberIn4)
})();

tips 未通过全部用例 部分用例超时

参考实现

思路

其实看题目有想过是进制的解法,但是之前了解的进制都是满n进1,但是没有碰到这种满n+1的算法

算法思路如下
看位数是否大于进制数,如果大于 则当前位-1乘以进度的当前位次方,如果不大于则直接用当前位乘以进度的当前位次方

可能比较抽象,这里举两个🌰

这题的进制数是4 进度是9

以100为🌰

1 < 4 用1 * 9^2 = 81

0 < 4 用0 * 9^1 = 0

0 < 4 用0 * 9^0 = 0

最终得出81

再以501为🌰

5 > 4? (5 - 1) * 9 ^2 = 324

0 > 4? 0 * 9 ^1

1 > 4? 1 * 9 ^0 = 1

最终得 325

源码实现

js 复制代码
 const rl = require("readline").createInterface({ input: process.stdin });
var iter = rl[Symbol.asyncIterator]();
const readline = async () => (await iter.next()).value;

void (async function () {
    // 输入实际付费的钱
    const payCount = await readline();
    let result = 0
    for (let i = 0 ; i < payCount.length; i++) {
        result += payCount[i] > 4 ? (payCount[i] - 1) * Math.pow(9, payCount.length - i - 1) : payCount[i]  * Math.pow(9, payCount.length - i - 1)
    }
    console.log(result)
})();
相关推荐
嵌入式学习菌4 天前
【AI面板识别】
华为od
小林rr6 天前
【华为OD机考】2024E+D卷真题【完全原创题解 详细考点分类 不断更新题目 六种主流语言Py+Java+Cpp+C+Js+Go】
java·c语言·华为od
郝晨妤7 天前
[HarmonyOS]鸿蒙(添加服务卡片)推荐商品 修改卡片UI(内容)
华为od·华为·harmonyos·鸿蒙
油泼辣子多加9 天前
【华为OD机考】华为OD笔试真题解析(7)--基站维修工程师
算法·华为od
CodeClimb13 天前
【华为OD-E卷 - 120 分割数组的最大差值 100分(python、java、c++、js、c)】
java·javascript·c++·python·华为od
执着的小火车14 天前
【2024华为OD-E卷-100分-箱子之字形摆放】((题目+思路+Java&C++&Python解析)
java·数据结构·算法·华为od
执着的小火车15 天前
【2024华为OD-E卷-100分-日志排序】((题目+思路+Java&C++&Python解析)
数据结构·算法·华为od·华为
CodeClimb15 天前
【华为OD-E卷 - 113 跳格子2 100分(python、java、c++、js、c)】
java·javascript·c++·python·华为od
无限码力16 天前
最大矩阵的和
数据结构·算法·华为od·笔试·华为od e卷真题
CodeClimb17 天前
【华为OD-E卷 - 115 数组组成的最小数字 100分(python、java、c++、js、c)】
java·javascript·c++·python·华为od