美文网首页
2019-09-26 leetcode

2019-09-26 leetcode

作者: dgg99 | 来源:发表于2019-09-29 02:10 被阅读0次

1.整数反转
假设我们的环境只能存储得下 32 位的有符号整数,则其数值范围为 [−231, 231 − 1]。请根据这个假设,如果反转后整数溢出那么就返回 0。

方法一(自己实现的)

class Solution {
    public int reverse(int x) {
                long sum = 0;
        while (x != 0) {
            int temp = x % 10;
            sum = sum * 10 + temp;
            x = x / 10;
        }
        if(sum > Integer.MAX_VALUE || sum < Integer.MIN_VALUE) return 0;
        else return (int)sum;
    }
}

方法二(有时间记得看)

public int reverse(int x) {
        if (x == 0)
            return 0;
        StringBuilder s = new StringBuilder();
        char[] num1 = "2147483647".toCharArray();
        char[] num2 = "2147483648".toCharArray();

        int num = x < 0 ? -x : x;
        while (num != 0) {
            s.append(num % 10);
            num /= 10;
        }
        if (s.length() > 10)
            return 0;

        if (s.length() == 10) {
            if (x > 0) {
                for (int i = 0; i < s.length(); i++) {
                    if (s.charAt(i) - '0' > num1[i] - '0')
                        return 0;
                    else if (s.charAt(i) - '0' < num1[i] - '0')
                        break;
                }
            } else {
                for (int i = 0; i < s.length(); i++) {
                    if (s.charAt(i) - '0' > num2[i] - '0')
                        return 0;
                    else if (s.charAt(i) - '0' < num2[i] - '0')
                        break;
                }
            }
        }
        return x < 0 ? Integer.parseInt("-" + s.toString()) : Integer.parseInt(s.toString());
    }

2.回文数
自己的思路就是将数字以字符数组的形式读入
然后利用一个while循环进行判断
然而官方给了一种解答很巧妙

public class Solution {
    public bool IsPalindrome(int x) {
        // 特殊情况:
        // 如上所述,当 x < 0 时,x 不是回文数。
        // 同样地,如果数字的最后一位是 0,为了使该数字为回文,
        // 则其第一位数字也应该是 0
        // 只有 0 满足这一属性
        if(x < 0 || (x % 10 == 0 && x != 0)) {
            return false;
        }
        int revertedNumber = 0;
        while(x > revertedNumber) {
            revertedNumber = revertedNumber * 10 + x % 10;
            x /= 10;
        }
        // 当数字长度为奇数时,我们可以通过 revertedNumber/10 去除处于中位的数字。
        // 例如,当输入为 12321 时,在 while 循环的末尾我们可以得到 x = 12,revertedNumber = 123,
        // 由于处于中位的数字不影响回文(它总是与自己相等),所以我们可以简单地将其去除。
        return x == revertedNumber || x == revertedNumber/10;
    }
}

3.罗马数字转整数
问题 那些简单加的比较简单,那些需要减处理的较麻烦。
初步想到的就是switch函数,根据每次独到的字符决定进行什么操作。

HashMap我觉得是最优的

class Solution {
    public int romanToInt(String s) {
        Map<String, Integer> map = new HashMap<>();
        map.put("I", 1);
        map.put("IV", 4);
        map.put("V", 5);
        map.put("IX", 9);
        map.put("X", 10);
        map.put("XL", 40);
        map.put("L", 50);
        map.put("XC", 90);
        map.put("C", 100);
        map.put("CD", 400);
        map.put("D", 500);
        map.put("CM", 900);
        map.put("M", 1000);
       
        int ans = 0;
        for(int i = 0;i < s.length();) {
            if(i + 1 < s.length() && map.containsKey(s.substring(i, i+2))) {
                ans += map.get(s.substring(i, i+2));
                i += 2;
            } else {
                ans += map.get(s.substring(i, i+1));
                i ++;
            }
        }
        return ans;
    }
}

作者:guanpengchn

        int ans = 0;//不初始化无法编译
        for(int i = 0; i < s.length(); i++){
            if(i < s.length() - 1 && map.containsKey(s.substring(i, i + 2))){//这里注意一定需要&&而不能用&。
                ans += map.get(s.substring(i, i + 2));
                i++;
            }else{
                ans += map.get(s.substring(i, i + 1));
            }
        }

重要函数

string.substring(int, int)
map.put(key, value);
map.get(key);

4.最长公共前缀
初步思路就想到了,第一个for()找出最短串的长度,然后就是双重for()。

lettcode

public class Main {

    public static void main(String[] args) {
        // write your code here
        //int[] bits = {1, 0, 0, 0};
        System.out.println(new Main().longestCommonPrefix(new String[]{"flower", "flow", "flight"}));
        //注意定义字符数组和定义字符串数组的区别
    }

    public String longestCommonPrefix(String[] strs) {
        if (strs.length == 0) return "";
        String prefix = strs[0];
        for (int i = 1; i < strs.length; i++)
            while (strs[i].indexOf(prefix) != 0) {//自己写的时候这里写错
                prefix = prefix.substring(0, prefix.length() - 1);
                if (prefix.isEmpty()) return "";//注意判断位置,位置放不好会引起死循环
            }
        return prefix;
    }
}

重要函数
String.indexOf(String);
new String[]{"flower", "flow", "flight"};建立字符串数组

相关文章

网友评论

      本文标题:2019-09-26 leetcode

      本文链接:https://www.haomeiwen.com/subject/ruqnuctx.html