zoukankan      html  css  js  c++  java
  • LintCode 31. 数组划分

    这题反正一看就是和快排的nlogn中的一次n,使用两个指针,要注意的就是考虑各种边界条件,从数组的右边开始,遇到==k的值也往下搜索,而从数组左边开始的指针遇到k值不往上搜索,这样的话就可以控制如果出现重复k值的情况,的到的结果是最先出现的坐标,如果题目要求得到最右边的k的坐标就用左边==k也往上搜索就行

    import org.junit.Test;
    
    import java.util.Arrays;
    
    public class PartitionArray {
        /**
         * @param nums: The integer array you should partition
         * @param k:    An integer
         * @return: The index after partition
         * <p>
         * 31. 数组划分
         * 给出一个整数数组 nums 和一个整数 k。划分数组(即移动数组 nums 中的元素),使得:
         * <p>
         * 所有小于k的元素移到左边
         * 所有大于等于k的元素移到右边
         * 返回数组划分的位置,即数组中第一个位置 i,满足 nums[i] 大于等于 k。
         * <p>
         * 样例
         * 给出数组 nums = [3,2,2,1] 和 k = 2,返回 1.
         * <p>
         * 挑战
         * 使用 O(n) 的时间复杂度在数组上进行划分。
         * <p>
         * 注意事项
         * 你应该真正的划分数组 nums,而不仅仅只是计算比 k 小的整数数,如果数组 nums 中的所有元素都比 k 小,则返回 nums.length。
         */
        public int partitionArray(int[] nums, int k) {
            // write your code here
            int i = 0;
            int j = nums.length - 1;
            int temp = 0;
            if (nums.length == 0) {
                return 0;
            }
            while (j > i) {
                while (nums[j] >= k && j > i) {
                    j--;
                }
                while (nums[i] <= k && j > i) {
                    i++;
                }
                temp = nums[j];
                nums[j] = nums[i];
                nums[i] = temp;
            }
            //考虑是否是所有的值的大于等于k
            if (i == 0 && nums[0] >= k) {
                return i;
            }
            return i + 1;
        }
    
        @Test
        public void testQuickSort() {
    //        int[] nums = {3, 2, 2, 1};
            //3
            int[] nums = {3, 2, 3, 3, 2, 1};
            System.out.println(partitionArray(nums, 2));
            System.out.println(Arrays.toString(nums));
        }
    }
    
  • 相关阅读:
    统计内存使用情况
    自动化测试---PO设计模式
    初识xshell
    pip插件遇到问题(fetch URL https)
    为什么大家都热衷于挖矿呢?
    80个python练习以及python一些值得收藏的教程或博客
    面试问到一个,让你写一下朋友圈点赞功能的测试用例!记录一下
    ajax异步请求302
    Java学习
    MVC 带扩展名的路由无法访问
  • 原文地址:https://www.cnblogs.com/wei1/p/9582042.html
Copyright © 2011-2022 走看看