PTA 7-1 公路村村通,Java实现

现有村落间道路的统计数据表中,列出了有可能建设成标准公路的若干条道路的成本,求使每个村落都有公路连通所需要的最低成本。

输入格式:

输入数据包括城镇数目正整数 n(≤1000)和候选道路数目 m(≤3n);随后的 m 行对应 m 条道路,每行给出 3 个正整数,分别是该条道路直接连通的两个城镇的编号以及该道路改建的预算成本。为简单起见,城镇从 1 到 n 编号。

输出格式:

输出村村通需要的最低成本。如果输入数据不足以保证畅通,则输出 −1,表示需要建设更多公路。

输入样例:

6 15
1 2 5
1 3 3
1 4 7
1 5 4
1 6 2
2 3 4
2 4 6
2 5 2
2 6 6
3 4 6
3 5 1
3 6 1
4 5 10
4 6 8
5 6 3

输出样例:

12

 Java实现,使用了克鲁斯卡尔算法

import java.util.Scanner;
import java.util.Arrays;

public class Main {
    final int Error=-1;
    final int Max=100010;

    int []parent;
    int n,m;
    Edge[]edges;
    public Main(){
        Scanner sc=new Scanner(System.in);
        n=sc.nextInt();
        m=sc.nextInt();
        parent=new int[n+1];
        edges=new Edge[m];
        for(int i=0;i<m;i++){
            edges[i]=new Edge();
            edges[i].start=sc.nextInt();
            edges[i].end=sc.nextInt();
            edges[i].weight=sc.nextInt();
        }
        int ans = Kruskal();
        System.out.println(ans);
    }
    public int Find(int v){
        while(parent[v]!=v){
            v=parent[v];
        }
        return v;
    }
    public int Kruskal(){
        int ans=0;
        int count=0;
        for(int i=0;i<parent.length;i++){
            parent[i]=i;
        }
        Arrays.sort(edges,(o1,o2)->o1.weight-o2.weight);
        for(int i=0;i<edges.length;i++){
            int a=Find(edges[i].start);
            int b=Find(edges[i].end);
            if(a!=b){
                parent[a]=b;
                ans=ans+edges[i].weight;
                count++;
            }
        }
        if(count<n-1){
            return -1;
        }
        return ans;
    }
    public static void main(String[]args){
        Main Solution = new Main();
    }
}
class Edge{
    int start,end,weight;
    public Edge(int start,int end,int weight){
        this.start=start;
        this.end=end;
        this.weight=weight;
    }
    public Edge(){}
}

不懂的私信我

### PTA 7-46 题目 Java 实现解决方案 对于PTA平台上的题目,采用高效的输入输出方式能够显著提升程序性能。针对Java语言而言,使用`BufferedReader`进行字符流输入可以有效减少时间消耗,防止因输入操作而导致的超时问题[^1]。 下面是一个基于此原则设计的PTA 7-46题目的Java实现案例: 假设该题目涉及处理一系列整数并执行特定逻辑运算,则可以通过如下方式进行编码: ```java import java.io.BufferedReader; import java.io.IOException; import java.io.InputStreamReader; public class Main { public static void main(String[] args) throws IOException { BufferedReader br = new BufferedReader(new InputStreamReader(System.in)); String line; while ((line = br.readLine()) != null && !line.isEmpty()){ // 对读取到的数据做进一步解析和处理 // 示例:将字符串形式的一行数字转换成int数组 int[] nums = java.util.Arrays.stream(line.split(" ")) .mapToInt(Integer::parseInt) .toArray(); // 执行具体的业务逻辑... // 输出结果 System.out.println(/* 计算后的结果 */); } } } ``` 为了确保解答的质量与准确性,在编写代码过程中需要注意以下几个要点: - **深入理解数据结构**:合理选用合适的数据结构来存储中间计算结果或辅助变量,比如本例中的`Map`或其他集合类容器[^3]。 - **考虑边界条件**:务必考虑到各种极限情况下的行为表现,如空输入、最大/最小值等情况,以此保障算法鲁棒性。 - **优化算法效率**:不断探索更加高效的方法论去简化现有流程,力求达到最优解法;同时也要兼顾可读性和易维护性的平衡. 通过上述措施的应用,不仅有助于提高代码质量,还能增强应对复杂场景的能力。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值