题解 | #正则序列#

正则序列

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(),复杂度就不是O(n)了啊,虽然依旧可以AC。。
点赞 回复 分享
发布于 2022-10-25 21:07 广东
Arrays.sort(nums,1,n);因为你排序的时候写错了,应该写成Arrays.sort(nums,1,n + 1);
点赞 回复 分享
发布于 2022-08-07 10:46

相关推荐

不愿透露姓名的神秘牛友
07-09 16:15
我应届生,去年10月份开始在这家公司实习,到今年10月份正好一年想(实习+试用期),在想要不要提前9月份就离职,这样好找工作些,但又差一个月满一年,又怕10月份国庆回来离职,容易错过了下半年的金九银十,到年底容易gap到年后
小破站_程序员YT:说这家公司不好吧,你干了快一年 说这家公司好吧,你刚毕业就想跑路说你不懂行情吧,你怕错过金九银十说 你懂行情吧,校招阶段在实习,毕业社招想换工作 哥们,我该怎么劝你留下来呢
应届生,你找到工作了吗
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务