Leetcode-1523. 在区间范围内统计奇数数目

题目:

给你两个非负整数 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

第一种方法,直接判断奇数偶数,是奇数,计数器++;

java 复制代码
class Solution {
    public int countOdds(int low, int high) {

    int cnt = 0;

    if(low%2!=0){
        while(low<=high){
            cnt++;
            low+=2;
        }
    }
    if(low%2==0){
        low++;
        while(low<=high){
            cnt++;
            low+=2;
        }
    }
    
    return cnt;
    }
}

第二种,列出所有情况,high-low=0;low奇,high偶;high奇,low偶;low、high全奇全偶。

java 复制代码
class Solution {
    public int countOdds(int low, int high) {
        int cnt = 0;
        if(high-low==0){
            if(low%2==0)return cnt;
            return cnt+1;
        }
        if(low%2==0&&high%2==0){
            cnt+=(high-low)/2;
        }else if(low%2!=0&&high%2!=0){
            cnt+=((high-low)/2+1);
        }else{
            cnt+=(high-low+1)/2;
        }
        return cnt;
    }
}

第三种,一行代码秒杀!

java 复制代码
class Solution {
    public int countOdds(int low, int high) {
        return (high+1)/2 - low/2;
    }
}
相关推荐
star数模3 分钟前
2024“华为杯”中国研究生数学建模竞赛(E题)深度剖析_数学建模完整过程+详细思路+代码全解析
python·算法·数学建模
Tak1Na6 分钟前
2024.9.19
算法
sjsjs1125 分钟前
【数据结构-扫描线】力扣57. 插入区间
数据结构·算法·leetcode
lj90772264426 分钟前
Dockerfile部署xxljob
java·docker
王哈哈嘻嘻噜噜27 分钟前
数据结构中线性表的定义和特点
数据结构·算法
多则惑少则明36 分钟前
idea 编辑器常用插件集合
java·编辑器·intellij-idea
一杯茶一道题1 小时前
LeetCode 260. 只出现一次的数字 III
算法·leetcode
BLUcoding1 小时前
RabbitMQ08_保证消息可靠性
java·rabbitmq
MogulNemenis1 小时前
力扣415周赛
java·数据结构·算法·leetcode
ai安歌1 小时前
【JavaWeb】利用IDEA2024+tomcat10配置web6.0版本搭建JavaWeb开发项目
java·开发语言·后端·tomcat·web·intellij idea