LeetCode 1523.在区间范围内统计奇数数目:两种方法O(1)算

【LetMeFly】1523.在区间范围内统计奇数数目:两种方法O(1)算

力扣题目链接:https://leetcode.cn/problems/count-odd-numbers-in-an-interval-range/

给你两个非负整数 lowhigh 。请你返回lowhigh之间(包括二者)奇数的数目。

示例 1:

复制代码
输入:low = 3, high = 7
输出:3
解释:3 到 7 之间奇数数字为 [3,5,7] 。

示例 2:

复制代码
输入:low = 8, high = 10
输出:1
解释:8 到 10 之间奇数数字为 [9] 。

提示:

  • 0 <= low <= high <= 10^9

解题方法一:思考容易写着麻烦点

low和high都是偶数的示例 2:low = 8, high = 10,中间共有几个奇数?

答案是 10 − 8 2 \frac{10-8}2 210−8个。

如果low是奇数,那么我们令low-1;如果high是奇数,那么我们就令high+1就好了。

  • 时间复杂度 O ( 1 ) O(1) O(1)
  • 空间复杂度 O ( 1 ) O(1) O(1)

AC代码

C++
cpp 复制代码
/*
 * @LastEditTime: 2026-02-19 17:39:31
 */
class Solution {
public:
    int countOdds(int low, int high) {
        if (low % 2) {
            low--;
        }
        if (high % 2) {
            high++;
        }
        return (high - low) >> 1;
    }
};
Python
python 复制代码
'''
LastEditTime: 2026-02-19 18:00:11
'''
class Solution:
    def countOdds(self, low: int, high: int) -> int:
        if low % 2:
            low -= 1
        if high % 2:
            high += 1
        return (high - low) // 2
Go
go 复制代码
/*
 * @LastEditTime: 2026-02-19 18:02:40
 */
package main

func countOdds(low int, high int) int {
    if low % 2 == 1 {
        low--
    }
    if high % 2 == 1 {
        high++
    }
    return (high - low) / 2
}

解题方法二:思考麻烦点写着容易

不论一个数的奇偶性:

  • [ 1 , l o w ) [1, low) [1,low) 共有几个奇数?答案是 ⌊ l o w 2 ⌋ \lfloor\frac{low}2\rfloor ⌊2low⌋个;
  • 1 , h i g h 1, high 1,high 共有几个奇数?答案是 ⌊ h i g h + 1 2 ⌋ \lfloor\frac{high+1}2\rfloor ⌊2high+1⌋个。

那么 l o w , h i g h low, high low,high 共有几个奇数? 1 , h i g h 1 , l o w ) \[1, high - 1, low) \[1,high−[1,low) 即为所得。

  • 时间复杂度 O ( 1 ) O(1) O(1)
  • 空间复杂度 O ( 1 ) O(1) O(1)

AC代码

Java
java 复制代码
/*
 * @LastEditTime: 2026-02-19 18:04:04
 */
class Solution {
    public int countOdds(int low, int high) {
        return (high + 1) / 2 - low / 2;
    }
}
Rust
rust 复制代码
/*
 * @LastEditTime: 2026-02-19 18:06:07
 */
impl Solution {
    pub fn count_odds(low: i32, high: i32) -> i32 {
        (high + 1) / 2 - low / 2
    }
}

同步发文于CSDN和我的个人博客,原创不易,转载经作者同意后请附上原文链接哦~

千篇源码题解已开源

相关推荐
这料鬼有毒20 小时前
二刷hot100-78.子集
算法·leetcode·职场和发展
ZHW_AI课题组21 小时前
使用DBSCAN算法对纽约市 Airbnb 房源数据集进行聚类分析
算法
蓦然回首却已人去楼空21 小时前
【分词:中文分词】BPE字节级分词算法实现汉字表达!
java·算法·中文分词
3DVisionary21 小时前
aero-engine-blade-thermal-fatigue-dic-inspection
人工智能·算法·机器学习·航空发动机·高温dic·涡轮叶片·热疲劳
Kurisu57521 小时前
深度拆解:从二进制切片到并发控制,大文件断点续传的底层工程设计
算法
随意起个昵称1 天前
线性dp-LIS题目2(导弹拦截III)
算法·动态规划·图论
地平线开发者1 天前
工具链使用从入门到顺手
算法
明航咨询—张老师1 天前
AI工具狂飙时代:三款实用AI产品深度横向测评
大数据·人工智能·算法·it
医用门1 天前
医院钢制门厂家有哪些品牌好的
leetcode