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));
        }
    }
    
  • 相关阅读:
    MIX11大会WP7主题演讲中文字幕版
    日本战神——源义经
    System.Web.HttpUtility for .Net Compact Framework
    VS2010 SP1
    <如何成为一个成功的职业经理人>读书笔记2
    <左手曾国藩,右手胡雪岩>读书笔记
    <福布斯荐75本经商必读06基业长青>读书笔记
    <中国人聪明之道>读书笔记
    <浮沉>读书笔记
    <79个潜规则:改变生活的心理学法则>读书笔记
  • 原文地址:https://www.cnblogs.com/wei1/p/9582042.html
Copyright © 2011-2022 走看看