LeetCode-1822/1502/896/13

2024-01-08 11:00:49

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

文章来源:https://blog.csdn.net/qq_45965652/article/details/135449328
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。