• 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));
        }
    }
    
  • 相关阅读:
    Linux下Redis的安装和部署
    js实现复制到剪贴板功能,兼容所有浏览器
    解决file_get_contents无法请求https连接的方法
    PHP使用正则表达式验证电话号码(手机和固定电话)
    php MYSQL 一条语句中COUNT出不同的条件
    学到的较复杂的 mysql 语名
    数据库相关 sql 语句
    php对象比较
    魔术方法
    inner join left join right join
  • 原文地址:https://www.cnblogs.com/wei1/p/9582042.html
Copyright © 2020-2023  润新知