A.每日一题——1523. 在区间范围内统计奇数数目

题目链接:1523. 在区间范围内统计奇数数目(简单)

算法原理:

解法:前缀和思想

击败100.00%

时间复杂度O(1)

一次遍历相信大家都会,但时间复杂度会达到O(N),题目要求统计区间内的奇数,恰好奇数偶数是连续存在的,那有没有更快的方法呢?有的!兄弟有的!

既然是一奇一偶,那么÷2不就得了?不对的,这里要视边界而论

我们选择区间[low,high]

当low是奇数时,它前面的奇数在[0,low),有low/2个

当low是偶数时,它前面的奇数在[0,low),也是low/2个

当high是奇数时,它前面的奇数在[0,high),但它自己也要算上,所以是high/2+1个

当high是偶数时,它前面的奇数在[0,high),是high/2个

由于 / 在int中只会取整数,所以high是偶数时可以写成(high+1)/2个,这与high是奇数时的high/2+1是等价的,所以都可以写成(high+1)/2

那么直接返回 (high+1)/2-low/2就行了

Java代码:

java 复制代码
class Solution {
    public int countOdds(int low, int high) {
        return (high+1)/2-low/2;
    }
}
相关推荐
XH华2 分钟前
数据结构第九章:树的学习(下)
数据结构·学习
大数据新鸟6 分钟前
操作系统之虚拟内存
java·服务器·网络
Tong Z7 分钟前
常见的限流算法和实现原理
java·开发语言
凭君语未可11 分钟前
Java 中的实现类是什么
java·开发语言
He少年13 分钟前
【基础知识、Skill、Rules和MCP案例介绍】
java·前端·python
前端大波21 分钟前
前端面试通关包(2026版,完整版)
前端·面试·职场和发展
克里斯蒂亚诺更新23 分钟前
myeclipse的pojie
java·ide·myeclipse
迷藏49441 分钟前
**eBPF实战进阶:从零构建网络流量监控与过滤系统**在现代云原生架构中,**网络可观测性**和**安全隔离**已成为
java·网络·python·云原生·架构
迷藏49442 分钟前
**发散创新:基于Solid协议的Web3.0去中心化身份认证系统实战解析**在Web3.
java·python·web3·去中心化·区块链
qq_433502181 小时前
Codex cli 飞书文档创建进阶实用命令 + Skill 创建&使用 小白完整教程
java·前端·飞书