【LeetCode——编程能力入门第一天】基本数据类型[在区间范围内统计奇数数目/去掉最低工资和最高工资后的工资平均值)

简介: 给你两个非负整数 low 和 high 。请你返回 low 和 high 之间(包括二者)奇数的数目。示例 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。

目录

题目:在区间范围内统计奇数数目

错误示范:

分析:

解题:在区间范围内统计奇数数目

题目:去掉最低工资和最高工资后的工资平均值

错误示范:

For遍历

Arrays类


题目:在区间范围内统计奇数数目

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

示例 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。

错误示范:

class Solution {
    public int countOdds(int low, int high) {
    int sum=0;//累加和
//从low到hign依次遍历
    for(int i=low;i<=high;i++){
//判断为奇数则自加
        if(i%2!=0){
 sum++;
        } 
    }
    return sum;
    }
}

image.gif

最初想的直接循环遍历懒得动脑子了,咔咔咔敲完了测试之后发现超出了时间限制。想起来这应该是一道算法题。

分析:

我是这样想的,每个数都是按照奇数、偶数、奇数、偶数、这样循环往复的。可以分为三种可能low和height同为奇数就用(high-low)/2+1,如果同为偶数(high-low)/2,如果两个都是一个奇数一个偶数可以使用(high-low+1)/2

同为奇数:

image.gif编辑

同为偶数

image.gif编辑

一奇一偶

image.gif编辑

解题:在区间范围内统计奇数数目

class Solution {
    public int countOdds(int low, int high) {
    if(low%2!=0&&high%2!=0){
        return (high-low)/2+1;
    }else if(low%2==0&&high%2==0){
     return (high-low)/2;
    }else if(low%2!=0&&high%2==0||low%2==0&&high%2!=0){
     return (high-low+1)/2;
    }
return 0;
}
}

image.gif

题目:去掉最低工资和最高工资后的工资平均值

给你一个整数数组 salary ,数组里每个数都是 唯一 的,其中 salary[i] 是第 i 个员工的工资。

请你返回去掉最低工资和最高工资以后,剩下员工工资的平均值。

示例 1:

输入:salary = [4000,3000,1000,2000]

输出:2500.00000

解释:最低工资和最高工资分别是 1000 和 4000 。

去掉最低工资和最高工资以后的平均工资是 (2000+3000)/2= 2500

示例 2:

输入:salary = [1000,2000,3000]

输出:2000.00000

解释:最低工资和最高工资分别是 1000 和 3000 。

去掉最低工资和最高工资以后的平均工资是 (2000)/1= 2000

示例 3:

输入:salary = [6000,5000,4000,3000,2000,1000]

输出:3500.00000

示例 4:

输入:salary = [8000,9000,2000,3000,6000,1000]

输出:4750.00000

 

提示:

3 <= salary.length <= 100

10^3 <= salary[i] <= 10^6

salary[i] 是唯一的。

与真实值误差在 10^-5 以内的结果都将视为正确答案。

错误示范:

没有

分析:我们使用Arrays类的sort方法可以进行排序但是for循环遍历也可以不会出问题

For遍历

class Solution {
    public double average(int[] salary) {
        double min=salary[0];//存放最小值
        double max=salary[0];//存放最大值
        double sum=0;//存放累加和
     for(int i=0;i<salary.length;i++){
         if(salary[i]>max){
             max=salary[i];
         }
         if(salary[i]<min){
             min=salary[i];
         }
//累加和存放
         sum+=salary[i];
     }
//减去最大值和最小值
     sum=sum-max-min;
     return sum/(salary.length-2);
    }
}

image.gif

Arrays类

class Solution {
    public double average(int[] salary) {
//进行自动排序
     Arrays.sort(salary);
//存放累加值
     double a=0;
//最大值最小值设置为0
     salary[0]=0;
     salary[salary.length-1]=0;
     for(int i=0;i<salary.length;i++){
     a+=salary[i];
     }
     return a/(salary.length-2);
    }
}

image.gif

CSDN社区 《创作达人》活动,只要参与其中并创作文章就有机会获得官方奖品:精品日历、新程序员杂志,快来参与吧!链接直达 https://bbs.csdn.net/topics/605272551  

目录
相关文章
|
2月前
|
Unix Shell Linux
LeetCode刷题 Shell编程四则 | 194. 转置文件 192. 统计词频 193. 有效电话号码 195. 第十行
本文提供了几个Linux shell脚本编程问题的解决方案,包括转置文件内容、统计词频、验证有效电话号码和提取文件的第十行,每个问题都给出了至少一种实现方法。
LeetCode刷题 Shell编程四则 | 194. 转置文件 192. 统计词频 193. 有效电话号码 195. 第十行
|
1月前
|
算法
Leetcode第57题(插入区间)
LeetCode第57题“插入区间”的解题方法,包括题目描述、示例、算法思路和代码实现,旨在解决将新区间插入有序且不重叠的区间列表中,并合并重叠区间的问题。
15 0
Leetcode第57题(插入区间)
|
3月前
|
算法
LeetCode第57题插入区间
LeetCode第57题"插入区间"的解题方法,利用原区间集有序的特性,通过三步插入操作,有效实现了新区间的插入和重叠区间的合并。
LeetCode第57题插入区间
|
3月前
|
Python
【Leetcode刷题Python】剑指 Offer 21. 调整数组顺序使奇数位于偶数前面
Leetcode题目"剑指 Offer 21. 调整数组顺序使奇数位于偶数前面"的两种Python解决方案,一种是使用双端队列调整数组顺序,另一种是使用双指针法将奇数移到数组前半部分,偶数移到后半部分。
28 4
|
3月前
|
存储 算法 Java
LeetCode初级算法题:反转链表+统计N以内的素数+删除排序数组中的重复项Java详解
LeetCode初级算法题:反转链表+统计N以内的素数+删除排序数组中的重复项Java详解
44 0
|
5月前
|
存储 算法 测试技术
力扣经典150题第四十七题:汇总区间
力扣经典150题第四十七题:汇总区间
37 1
|
4月前
|
存储 算法
经典的滑动窗口的题目 力扣 2799. 统计完全子数组的数目(面试题)
经典的滑动窗口的题目 力扣 2799. 统计完全子数组的数目(面试题)
|
5月前
|
存储 SQL 算法
高效日程管理:利用区间合并算法优化活动安排【python LeetCode57】
高效日程管理:利用区间合并算法优化活动安排【python LeetCode57】
|
5月前
|
存储 算法 数据可视化
【模拟面试问答】深入解析力扣163题:缺失的区间(线性扫描与双指针法详解)
【模拟面试问答】深入解析力扣163题:缺失的区间(线性扫描与双指针法详解)
|
4月前
2670.找出不同元素数目差数组-力扣(LeetCode)
2670.找出不同元素数目差数组-力扣(LeetCode)
32 0