当前位置:网站首页>【LeetCode——编程能力入门第一天】基本数据类型[在区间范围内统计奇数数目/去掉最低工资和最高工资后的工资平均值)
【LeetCode——编程能力入门第一天】基本数据类型[在区间范围内统计奇数数目/去掉最低工资和最高工资后的工资平均值)
2022-07-17 05:04:00 【Super大雄】
目录
题目:在区间范围内统计奇数数目
给你两个非负整数 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);
}
}CSDN社区 《创作达人》活动,只要参与其中并创作文章就有机会获得官方奖品:精品日历、新程序员杂志,快来参与吧!链接直达 https://bbs.csdn.net/topics/605272551
边栏推荐
- Encryption and decryption
- CVE-2020-10199 Nexus Repository Manager3远程命令执行漏洞复现
- Hire the server, and the pytorch environment training yolov5 model tutorial deployed on pycharm professional edition. Server environment installation library file:
- User management - restrictions
- PyGame installation -requirement already satisfied
- Asynchronous data SMS verification code
- 学习C语言的第五天
- 第十届泰迪杯数据挖掘挑战赛A题害虫识别YOLOv5模型代码(已跑通,原创作品,持续更新)
- pygame-飞机大战1.0(步骤+窗口无响应问题)
- Mysql database experiment training 6, data view (detailed)
猜你喜欢
随机推荐
[batch] batch delete intermediate folder - personal research script
CVE-2022-23131 Zabbix SAML SSO认证绕过漏洞
Harmonyos入门
Flask的使用
String string special interception processing according to symbols
DSL search results processing, including sorting, paging, highlighting
C语言初学者之初识代码专项练习
02_ Movie recommendation (contentbased)_ User portrait
机器学习之PCA特征降维+案例实践
数据可视化
Conception finale: système distribué de gestion de la santé pour la prévention des épidémies hautement simultanées basé sur vue + socket + redis
Modelarts second training notes
用户管理-分页
Simply and quickly establish a pytorch environment yolov5 target detection model to run (super simple)
决策树原理和案例应用-泰坦尼克号生存预测
POC——DVWA‘s File Upload
HarmonyOS第四次培训笔记
关于当前响应已经调用了方法getOutputStream()
机器学习之特征提取(类别特征进行数值化、离散化、文本特征进行数值化)
学习C语言第三天








