大家好我是苏麟 , 今天带来算法通关村番外篇-LeetCode编程从0到1系列五 .
数学
1523. 在区间范围内统计奇数数目
描述 :
给你两个非负整数 low
和 high
。请你返回 low
和 high
之间(包括二者)奇数的数目。
题目 :
LeetCode 1523. 在区间范围内统计奇数数目
代码 :
class Solution {public int countOdds(int low, int high) {return pre(high) - pre(low - 1);}public int pre(int x) {return (x + 1) >> 1;}
}
67. 二进制求和
描述 :
给你两个二进制字符串 a
和 b
,以二进制字符串的形式返回它们的和。
题目 :
LeetCode 67. 二进制求和
代码 :
class Solution {public String addBinary(String a, String b) {StringBuilder sb = new StringBuilder();int i = a.length() - 1;int j = b.length() - 1;int add = 0;while(i >= 0 ||j >= 0 || add != 0){int x = i >= 0 ? a.charAt(i) - '0' : 0;int y = j >= 0 ? b.charAt(j) - '0' : 0;int num = x + y + add;sb.append(num % 2);add = num / 2;i--;j--;}return sb.reverse().toString();}
}
1491.去掉最低工资和最高工资后的工资平均值
描述 :
给你一个整数数组 salary
,数组里每个数都是 唯一 的,其中 salary[i]
是第 i
个员工的工资。
请你返回去掉最低工资和最高工资以后,剩下员工工资的平均值。
题目 :
LeetCode 1491. 去掉最低工资和最高工资后的工资平均值
代码 :
class Solution {public double average(int[] salary) {Arrays.sort(salary);salary[0] = 0;for(int i = 1;i < salary.length - 1;i++){salary[0] += salary[i];}return salary[0] * 1.0 / (salary.length - 2);}
}
43. 字符串相乘
描述 :
给定两个以字符串形式表示的非负整数 num1
和 num2
,返回 num1
和 num2
的乘积,它们的乘积也表示为字符串形式。
注意:不能使用任何内置的 BigInteger 库或直接将输入转换为整数。
题目 :
LeetCode 43. 字符串相乘
代码 :
class Solution {public String multiply(String num1, String num2) {if (num1.equals("0") || num2.equals("0")) {return "0";}int length = num2.length() - 1;String x = "0";//123 2while(length >= 0){//两数相乘 123 45String temp = xString(num1,num2.charAt(length));//补充零String reString = addZo(temp,num2.length() - length - 1);//成品x = addString(reString,x);length--;}return x;}//填零public String addZo(String n,int i){StringBuilder sb = new StringBuilder(n);while(i > 0){sb.append(0);i--;}return sb.toString();}//两数相乘 123 2public String xString(String a,char b){StringBuilder sb = new StringBuilder();//2int length = a.length() - 1;//2int y = b - '0';int add = 0;while(length >= 0 || add != 0){//2int x = length >= 0 ? a.charAt(length) - '0' : 0;//4int temp = x * y + add;//4sb.append(temp % 10);add = temp / 10;length--;}return sb.reverse().toString();}//两数相加public String addString(String num1,String num2){int i = num1.length() - 1;int j = num2.length() - 1;StringBuilder sb = new StringBuilder();int add = 0;while(i >=0 || j >= 0 || add != 0){int x = i >= 0 ? num1.charAt(i) - '0' : 0;int y = j >= 0 ? num2.charAt(j) - '0' : 0;int num = x + y + add;sb.append(num % 10);add = num / 10;i--;j--;}return sb.reverse().toString();}
}
这期就到这里 , 下期见!