解题思路:

哪里有问题呀!只能过55%

注意事项:

参考代码:

import java.util.Arrays;

import java.util.Comparator;

import java.util.Scanner;


public class Main {

    private static int N;

    static int a[]=new int[11002];

    private static int count=0;

    private static Integer[][] b;

    private static Integer pre=-1;

public static void main(String[] args) {

    Scanner input=new Scanner(System.in);

    N=input.nextInt();

    int M=input.nextInt();

   b=new Integer[100002][3];

   for (int i = 1; i <=N; i++) {

    a[i]=i;

}

   for (int i = 1; i <=M; i++) {

    b[i][0]=input.nextInt();

    b[i][1]=input.nextInt();

    b[i][2]=input.nextInt();

}

   Arrays.sort(b,1,M+1,new Comparator<Integer[]>(){//从大到小排序


    @Override

    public int compare(Integer[] o1, Integer[] o2) {

    if(o1[2]>o2[2])

    return -1;

    else if(o1[2]<o2[2]){

    return 1;

    }

    else

    return 0;

    }

   });

    for (int i = 1; i <M+1; i++) {

    int way=unit(b[i][0],b[i][1]);

    if(pre!=b[i][2]&&way==1){

    count++;//记录次数

    pre=b[i][2];//改变天数

    }

}

  System.out.println(count);

}

private static int unit(Integer a1, Integer b1) {

    a1=find(a1);

    b1=find(b1);

    if(a1!=b1){

    a[b1]=a1;

    return 1;

    }

return 0;

}

private static Integer find(Integer a2) {

    if(a2==a[a2])return a2;

    else

    return  a[a2]=find(a[a2]);

}

}


点赞(0)
 

0.0分

0 人评分

C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:

一点编程也不会写的:零基础C语言学练课程

解决困扰你多年的C语言疑难杂症特性的C语言进阶课程

从零到写出一个爬虫的Python编程课程

只会语法写不出代码?手把手带你写100个编程真题的编程百练课程

信息学奥赛或C++选手的 必学C++课程

蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程

手把手讲解近五年真题的蓝桥杯辅导课程

评论列表 共有 0 条评论

暂无评论