首页 > 移动平台 > 详细

[小米OJ] 7. 第一个缺失正数

时间:2019-01-19 22:28:36      阅读:226      评论:0      收藏:0      [点我收藏+]

思路:

参考这个思路

即:将每个数字放在对应的第几个位置上,比如1放在第1个位置上,2放在第2个位置上.

注意几个点:将每个数放在它正确的位置,前提是该数是正数,并且该数小于序列长度,并且交换的两个数字不相等。

    private static String solution(String line) {
        String[] strs = line.split(",");
        int[] nums = new int[strs.length];
        for (int i = 0; i < nums.length; i++) {
            nums[i] = Integer.parseInt(strs[i]);
        }

        for (int i = 0; i < nums.length; i++) {
            while (nums[i] > 0 && nums[i] <= nums.length && nums[nums[i] - 1] != nums[i]) {
                int temp = nums[nums[i] - 1];
                nums[nums[i] - 1] = nums[i];
                nums[i] = temp;
            }
        }
        for (int i = 0; i < nums.length; i++) {
            if (nums[i] != i + 1)
                return (i + 1) + "";
        }
        return (nums.length + 1) + "";
    }

 

[小米OJ] 7. 第一个缺失正数

原文:https://www.cnblogs.com/ruoh3kou/p/10293497.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!