1.数组元素积的符号(1822)
题目描述:
已知函数 signFunc(x) 将会根据 x 的正负返回特定值:
如果 x 是正数,返回 1 。
如果 x 是负数,返回 -1 。
如果 x 是等于 0 ,返回 0 。
给你一个整数数组 nums 。令 product 为数组 nums 中所有元素值的乘积。
返回 signFunc(product) 。
思路: 这题比较简单,只需要初始设置一个变量为1,然后遍历数组,数组元素为正不操作,为0则直接返回0,为负则给设置的遍历乘以-1,最终返回该变量即可。但是这里要注意题目中谈到了signFunc函数,不过它实现起来也很简单。
代码:
class Solution {
public int arraySign(int[] nums) {
int sum=1;
for(int i=0;i<nums.length;i++) {
if(nums[i]==0) {
return signFunc(nums[i]);
} else if(nums[i]<0) {
sum*=signFunc(nums[i]);
}
}
return signFunc(sum);
}
public int signFunc(int n) {
if(n<0) {
return -1;
} else if(n==0) {
return 0;
} else {
return 1;
}
}
}
2.判断能否形成等差数列(1502)
题目描述:
给你一个数字数组 arr 。
如果一个数列中,任意相邻两项的差总等于同一个常数,那么这个数列就称为 等差数列 。
如果可以重新排列数组形成等差数列,请返回 true ;否则,返回 false 。
思路: 这里首先通过位置0与位置1元素的差得到差值,然后遍历数组,计算相邻两个元素的差,如果有一个差值不等于开始计算的差值,则直接返回false;
代码:
class Solution {
public boolean canMakeArithmeticProgression(int[] arr) {
Arrays.sort(arr);
int val=arr[1]-arr[0];
for(int i=1;i<arr.length-1;i++) {
if(val!=(arr[i+1]-arr[i])) {
return false;
}
}
return true;
}
}
3.单调数列(896)
题目描述:
如果数组是单调递增或单调递减的,那么它是 单调 的。
如果对于所有 i <= j,nums[i] <= nums[j],那么数组 nums 是单调递增的。 如果对于所有 i <= j,nums[i]> = nums[j],那么数组 nums 是单调递减的。
当给定的数组 nums 是单调数组时返回 true,否则返回 false。
思路一: 首先要得到第二个元素和第一个元素的差,这样我们才可以进行后续的判断,如果是正数则该数组可能单增,如果是负数则该数组可能单减。但是要注意一个问题,如果首部的元素都是相等的那么这种方法就适用不了了?还是可以的,只要加一个while循环遍历到不相等的数即可。得到差值后分两种情况,差值大于0的情况,用一个for循环不断得到相邻元素差值,如果有一个差值小于0返回false。差值小于0情况同理,有一个差值大于0返回false。如果没出现上述的false情况就返回true。
思路二: 因为数组不是单增就是单减,我们建立两个布尔型变量初始值设为true分别记录单增和单减的情况。使用一个循环对数组进行遍历,如果出现差值为负则将一个变量设为false,同理如果出现差值为正则将另一个变量设为false。然后遍历完成最后返回两个布尔型变量的||即可。具体看代码。
代码:
class Solution {
public boolean isMonotonic(int[] nums) {
return isMonotonic2(nums);
}
public boolean isMonotonic1(int[] nums) {
if(nums.length==1) {
return true;
}
boolean flg=true;
int k=1;
while(k<nums.length&&nums[0]==nums[k]) {
k++;
}
if(k==nums.length) {
return true;
}
if(nums[k]-nums[0]>0) {
for(int i=1;i<nums.length;i++) {
if(nums[i]-nums[i-1]<0) {
flg=false;
}
}
} else if(nums[k]-nums[0]<0){
for(int i=1;i<nums.length;i++) {
if(nums[i]-nums[i-1]>0) {
flg=false;
}
}
}
return flg;
}
public boolean isMonotonic2(int[] nums) {
boolean inc=true,der=true;
for(int i=1;i<nums.length;i++) {
if(nums[i]-nums[i-1]<0) {
inc=false;
}
if(nums[i]-nums[i-1]>0) {
der=false;
}
}
return inc||der;
}
}
4.罗马数字转整数(13)
题目描述:
罗马数字包含以下七种字符: I, V, X, L,C,D 和 M。
字符 数值
I 1
V 5
X 10
L 50
C 100
D 500
M 1000
例如, 罗马数字 2 写做 II ,即为两个并列的 1 。12 写做 XII ,即为 X + II 。 27 写做 XXVII, 即为 XX + V + II 。
通常情况下,罗马数字中小的数字在大的数字的右边。但也存在特例,例如 4 不写做 IIII,而是 IV。数字 1 在数字 5 的左边,所表示的数等于大数 5 减小数 1 得到的数值 4 。同样地,数字 9 表示为 IX。这个特殊的规则只适用于以下六种情况:
I 可以放在 V (5) 和 X (10) 的左边,来表示 4 和 9。
X 可以放在 L (50) 和 C (100) 的左边,来表示 40 和 90。
C 可以放在 D (500) 和 M (1000) 的左边,来表示 400 和 900。
给定一个罗马数字,将其转换成整数。
思路: 这里的思路是从左至右来处理这个字符串,设置返回数sum初值为0,如果遇到V L D M则直接在sum上加上相应的值。如果遇到I 则要判断下一个字母是否为V 或 X,如果是则加上4或9并且索引要多加一位,因为这里一次性处理掉了两个字符,如果下一个字母不是V或X则直接在sum上加上1就行。至于遇到X C与这里遇到I的处理是一致的不多赘述,具体看代码。
代码:
class Solution {
public int romanToInt(String s) {
int len=s.length();
int sum=0;
for(int i=0;i<len;i++) {
switch(s.charAt(i)) {
case 'I':
if(i+1<len&&s.charAt(i+1)=='V') {
sum+=4;
i++;
} else if(i+1<len&&s.charAt(i+1)=='X') {
sum+=9;
i++;
} else {
sum+=1;
}
break;
case 'V':
sum+=5;
break;
case 'X':
if(i+1<len&&s.charAt(i+1)=='L') {
sum+=40;
i++;
} else if(i+1<len&&s.charAt(i+1)=='C') {
sum+=90;
i++;
} else {
sum+=10;
}
break;
case 'L':
sum+=50;
break;
case 'C':
if(i+1<len&&s.charAt(i+1)=='D') {
sum+=400;
i++;
} else if(i+1<len&&s.charAt(i+1)=='M') {
sum+=900;
i++;
} else {
sum+=100;
}
break;
case 'D':
sum+=500;
break;
case 'M':
sum+=1000;
break;
}
}
return sum;
}
}