Rust-如何快速统计一个数字的位数

不吐不快:依旧是不想写论文的一天,终于把第二章基本写完了,还是愉快地刷题。但是今天力扣1295统计位数为偶数的数字的时候,十分想用迭代器写法,但是突然发现不怎么会统计位数,于是我使用AI帮我搜了一下,发现了一些惊为天人的方法(在我这里看来惊为天人,各位大佬肯定习以为常~)

常见的统计位数有两种方法,分别是逐位统计,或者转换为字符串求长度,那么还有其他的吗?

有的兄弟,有的。

废话不多说,我先把今天我遇到的一个题贴在这里。
1295. 统计位数为偶数的数字 - 力扣(LeetCode)

题目:给你一个整数数组nums,请你返回其中位数为偶数的数字的个数。
示例1:

输入:nums = 12, 345, 2, 6, 7896

输出:2

解释:

12 是 2 位数字(位数为偶数)

345 是 3 位数字(位数为奇数)

2 是 1 位数字(位数为奇数)

6 是 1 位数字 位数为奇数)

7896 是 4 位数字(位数为偶数)

因此只有 12 和 7896 是位数为偶数的数字

整个题目实际上是很简单的,但是我想用迭代器来写。

我先放一个我自己的版本:

Rust 复制代码
impl Solution {
    pub fn find_numbers(nums: Vec<i32>) -> i32 {
        nums.iter()
            .filter(|&x|) {
                x.to_string().len() % 2 == 0
            }
            .count() as i32
    }
}

一个平平无奇的字符串方法,或者你也可以用逐位统计的方法,while循环到底。

但是这里我突然发现可以使用log10,也就是把数字取对数,这个方法我还没查过效率是多少,但应该会比while高一些,个人感觉。如果有感兴趣的朋友可以测试一下。

代码我贴在下边:

Rust 复制代码
impl Solution {
    pub fn find_numbers(nums: Vec<i32>) -> i32 {
        nums.iter()
            .filter(|&x| {
                if *x == 0 {
                    return false;
                }
                let num = x.abs();
                let digits = (num.ilog10()+1) as usize;
                digits % 2 == 0
            })
            .count() as i32
    }
}

通过i32中的ilog10方法,同样能够实现统计位数的操作,不错不错,奇怪的知识又增加了!

好了,一个简单的问题就被我这么复杂的想了出来!

祝各位行行代码无BUG,次次科研出成果!

相关推荐
花褪残红青杏小19 小时前
Rust图像处理第11节-故障风 RGB 通道偏移:错位错色制造电子故障
rust·webassembly·图形学
花褪残红青杏小19 小时前
Rust图像处理第10节-浮雕/雕刻滤镜:邻域差值生成凹凸效果
rust·webassembly·图形学
Rockbean20 小时前
10分钟Solana-性能web3-2.4 Rust 编程基础三:结构体、枚举、错误处理与集合
rust·web3·智能合约
doiito1 天前
【Agent Harness】Gliding Horse 上下文感知与智能压缩:让 Agent 的“注意力”永不偏移
ai·rust·架构设计·系统设计·ai agent
花褪残红青杏小2 天前
Rust图像处理第9节-Sobel 边缘检测:第一个真正用卷积的算法
rust·webassembly·图形学
doiito2 天前
【Agent Harness】Gliding Horse L2 作战地图深度优化:给多 Agent 上下文装上“精准导航”
ai·rust·架构设计·系统设计·ai agent
花褪残红青杏小2 天前
Rust图像处理第8节-暗角 & 复古胶片特效:四周衰减中心高亮
rust·webassembly·图形学
独孤留白3 天前
从C到Rust:Rust 的 Trait 不是Interface,那是什么?
rust