基本数据类型(C语言专项练习)

目录

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

错误示范:

分析:

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

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

 错误示范:

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;
    }
}

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

分析:

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

同为奇数:

编辑

同为偶数

编辑

 一奇一偶

编辑

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

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;
}
}

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

给你一个整数数组 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);
    }
}

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);
    }
}
#C/C++#
全部评论
感谢分享,希望找工作能用到
点赞 回复 分享
发布于 2022-09-01 00:04 陕西

相关推荐

4 1 评论
分享
牛客网
牛客企业服务