美文网首页
2019-10-13 刷题总结 sort2

2019-10-13 刷题总结 sort2

作者: Leahlijuan | 来源:发表于2019-10-14 04:38 被阅读0次
  1. Intersection of Two Arrays
    求两个array的intersection,恰好昨天刚想了想这个问题,一个方法是A的每个元素和B的每个元素做对比,这种情况下复杂度为O(n^2), 并且还要考虑到重复元素的问题,用HashSet来解决可能有重复的问题。
    另一种方法是先将两个array排序,在用两个pointer挪动来获得intersection,时间复杂度是O(n lg n)。但这种情况下一定要注意重复的问题。
class Solution {
    public int[] intersection(int[] nums1, int[] nums2) {
        Arrays.sort(nums1);
        Arrays.sort(nums2);
        int i = 0, j = 0;
        List<Integer> list = new ArrayList<>();
        while (i < nums1.length && j < nums2.length) {
            if (nums1[i] == nums2[j]) {
                list.add(nums1[i]);
                while (i < nums1.length - 1 && nums1[i] == nums1[i+1]) {
                    i++;
                }
                while (j < nums2.length - 1 && nums2[j] == nums2[j+1]) {
                    j++;
                }
                i++;
                j++;
            } else if (nums1[i] < nums2[j]) {
                i++;
            } else {
                j++;
            }
        }
        int[] res = new int[list.size()];
        int k = 0;
        for (int e: list) {
            res[k] = e;
            k++;
        }
        return res;
    }
}
  1. Largest Number
    需要比较ab大还是ba大,就把这两个concat起来再比较。
    答案中比较好的方法是把他们作为String来进行比较,而不要转化为integer。
    因为原来是个int array,也必须要转化为integer array才能利用comparator进行比较。
class Solution {
    private class LargerNumberComparator implements Comparator<String> {
        @Override
        public int compare(String a, String b) {
            String order1 = a + b;
            String order2 = b + a;
           return order2.compareTo(order1);
        }
    }

    public String largestNumber(int[] nums) {
        // Get input integers as strings.
        String[] asStrs = new String[nums.length];
        for (int i = 0; i < nums.length; i++) {
            asStrs[i] = String.valueOf(nums[i]);
        }

        // Sort strings according to custom comparator.
        Arrays.sort(asStrs, new LargerNumberComparator());

        // If, after being sorted, the largest number is `0`, the entire number
        // is zero.
        if (asStrs[0].equals("0")) {
            return "0";
        }

        // Build largest number from sorted array.
        String largestNumberStr = new String();
        for (String numAsStr : asStrs) {
            largestNumberStr += numAsStr;
        }

        return largestNumberStr;
    }
}
  1. Valid Anagram
    判断s是否是t的permutation。
    先检查两者的长度是否相同。
    因为只包含lower case,可以用一个array来记录每个character出现的次数。
    traverse s的时候增加,traverse t的时候减少。当其中有个数量小于0,返回false。
class Solution {
    public boolean isAnagram(String s, String t) {
        if (s.length() != t.length()) {
            return false;
        }
        int[] chars = new int[26];
        for (char c: s.toCharArray()) {
            int index = c - 'a';
            chars[index] += 1;
        }
        for (char c: t.toCharArray()) {
            int index = c - 'a';
            chars[index] -= 1;
            if (chars[index] < 0) {
                return false;
            }
        }
        return true;
    }
}
  1. Maximum Gap
    bucket sort
    t = (max - min)/(n-1)
    t 是所有元素的平均距离,至少有两个元素的距离比t要大,因此我们要找的maximum gap肯定不会存在于同一个bucket中的两个元素,而是相邻的两个bucket。
class Solution {
    public int maximumGap(int[] nums) {
        if (nums.length < 2) {
            return 0;
        }
        int minNum = Integer.MAX_VALUE, maxNum = Integer.MIN_VALUE;
        for (int num: nums) {
            minNum = Math.min(minNum, num);
            maxNum = Math.max(maxNum, num);
        }
        // consider about the case all are the same
        int bucketSize = Math.max(1, (maxNum - minNum) / (nums.length - 1));
        // need to +1 to store the maximum element
        int numOfBucket = (maxNum - minNum)/bucketSize + 1;
        // store the maximum element of the bucket
        int[] max = new int[numOfBucket];
        int[] min = new int[numOfBucket];
        Arrays.fill(max, Integer.MIN_VALUE);
        Arrays.fill(min, Integer.MAX_VALUE);
        for (int num: nums) {
            int i = (num - minNum) / bucketSize;
            max[i] = Math.max(max[i], num);
            min[i] = Math.min(min[i], num);
        }
        int pre = max[0];
        int maxGap = 0;
        for (int j = 1; j < numOfBucket; j++) {
            if (pre == Integer.MIN_VALUE) {
                pre = max[j];
            } else {
                if (min[j] == Integer.MAX_VALUE) {
                    continue;
                } else {
                    maxGap = Math.max(maxGap, min[j] - pre);
                    pre = max[j];
                }
            }
        }
        return maxGap;
    }
}

相关文章

  • 2019-10-13 刷题总结 sort2

    Intersection of Two Arrays求两个array的intersection,恰好昨天刚想了想这...

  • PTA刷题总结-Part 3 数据结构与算法

    PTA刷题总结-Part 1 基础部分PTA刷题总结-Part 2 模拟与数学问题PTA刷题总结-Part 3 数...

  • PTA刷题总结-Part 2 模拟与数学问题

    PTA刷题总结-Part 1 基础部分PTA刷题总结-Part 2 模拟与数学问题PTA刷题总结-Part 3 数...

  • 刷题总结

    以前学习总觉得听懂了就会了,一直到现在都觉得。这几天忙考试,想着刷题吧,刷一个错一个,有因为题目没看清楚的但大...

  • 人生跃迁记录史

    早:刷题,图推,总结 中:资分刷题 晚:刷题总结,申论复习1小时 睡前回顾当天所需,学到了记住了什么清楚明白 高频...

  • 刷题总结(1)

    题目描述 给出一个数n,求1到n中,有多少个数不是2 5 11 13的倍数。 输入描述 本题有多组输入每行一个数n...

  • 算法刷题总结

    参考资料:[1]. 二叉搜索树转化为排序的二叉链表(《剑指offer》27题)[2]. 快速排序的基本思想[3]....

  • LeetCode刷题总结

    LeetCode刷题总结1 1.数字题 1.1 第一类 1.1.1 整数反转 给出一个 32 位的有符号整数,你需...

  • [Leetcode] 刷题总结

    个人github:https://github.com/nlpming/leetcode[https://gith...

  • leetcode|初级算法-数组

    01 起 刷题固然爽快,但及时总结才是进步之道,下面就数组部分的题目进行回顾和总结。 注意,刷题使用的语言是Pyt...

网友评论

      本文标题:2019-10-13 刷题总结 sort2

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