题解 | #正则序列#

正则序列

http://www.nowcoder.com/questionTerminal/0771ab500d424415af6b1aa4c13afcdd

import java.util.Scanner;
import java.util.*;


public class Main{


    public static void main(String[] args) {

        Scanner sc = new Scanner(System.in);
        int n = sc.nextInt();


        int[] nums = new int[n+1];
        boolean[] visted = new boolean[n+1];

        int VISITED = 10001;
        for(int i=1;i<=n;i++) nums[i] = sc.nextInt();
        Arrays.sort(nums,1,n);

        for(int i=1;i<=n;i++){
            if(nums[i]<=n && nums[i]>=1 && !visted[nums[i]] ) {
                visted[nums[i]] = true;
                nums[i] = VISITED;
            }
        }
        int res = 0;

        for(int i=1,j=1;i<=n;i++){
            if(!visted[i]){
                while(nums[j]==VISITED) j++;
                res += Math.abs(nums[j]-i);
                nums[j] = VISITED;
            }
        }

        System.out.println(res);
    }
}

这样 最后一个样例通不过 应该是在数组上面出问题了

不使用 n+1 的数组 就可以全部通过

import java.util.Scanner;
import java.util.*;


public class Main{


    public static void main(String[] args) {

        Scanner sc = new Scanner(System.in);
        int n = sc.nextInt();


        int[] nums = new int[n];

        for(int i=0;i<n;i++) nums[i] = sc.nextInt();
        Arrays.sort(nums);

        int res = 0;
        for(int i=1;i<=n;i++){
            res += Math.abs(nums[i-1]-i);
        }
        System.out.println(res);
    }
}

试卷解析 文章被收录于专栏

解析

全部评论
Arrays.sort(nums,1,n);因为你排序的时候写错了,应该写成Arrays.sort(nums,1,n + 1);
点赞 回复
分享
发布于 2022-08-07 10:46
用Arrays.sort(),复杂度就不是O(n)了啊,虽然依旧可以AC。。
点赞 回复
分享
发布于 2022-10-25 21:07 广东
滴滴
校招火热招聘中
官网直投

相关推荐

点赞 收藏 评论
分享
牛客网
牛客企业服务