大家好我是苏麟 , 今天带来算法通关村番外篇-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 2
while(length >= 0){
//两数相乘 123 45
String 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 2
public String xString(String a,char b){
StringBuilder sb = new StringBuilder();
//2
int length = a.length() - 1;
//2
int y = b - '0';
int add = 0;
while(length >= 0 || add != 0){
//2
int x = length >= 0 ? a.charAt(length) - '0' : 0;
//4
int temp = x * y + add;
//4
sb.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();
}
}
这期就到这里 , 下期见!