校招笔试题解-施工队的最大利润

简介:
import java.util.*;

/**
 * A国有n个城市,他们计划修建n1条长度为1的道路连接两个城市,城市规划已经给出,最终使得n个城市互相连通,
 * 从i城市到j城市有且只有一条唯一路径。
 * <p>
 * 有一家施工队计划承包两段道路的修建工作,要求这两段道路不经过相同的城市(包括路径端点),
 * 他们可以获得的利润是两段道路长度的乘积,现在要使得利润最大化,问最大能获得多少利润。
 * <p>
 * 输入:
 * 输入共有n行,第一行包含一个整数n,表示城市的数量。(n<=200)
 * <p>
 * 接下来有n-1行,每行有两个整数,a,b,表示在a城市和b城市之间存在一条长度为1的道路。
 * <p>
 * 输出:
 * 输出包含一行,表示最多可以获得的利润是多少
 * <p>
 * 样例输入
 * 4
 * 1 2
 * 2 3
 * 3 4
 * 样例输出
 * 1
 * <p>
 * 输入样例2
 * 6
 * 1 2
 * 2 3
 * 2 4
 * 5 4
 * 6 4
 * <p>
 * 输出样例2
 * 4
 * <p>
 * 样例解释
 * 样例2应该选取1-2-3和5-4-6,这样一来两条道路的长度都为2,利润最大为2*2
 *
 * @author Lean.Li
 * @date 2018/9/10
 */
public class Main {

    public static void main(String[] args) {
        Scanner input = new Scanner(System.in);
        int n = input.nextInt();
        boolean[][] arr = new boolean[n + 1][n + 1];
        HashMap<Integer, List<HashSet<Integer>>> list = new HashMap<>(n - 1);
        for (int i = 1; i < n; i++) {
            int a = input.nextInt();
            int b = input.nextInt();
            arr[a][b] = arr[b][a] = true;
        }
        input.close();
        findAllPaths(arr, n, list);
        int max = getMaxProfile(list, n);
        System.out.println(max);
    }

    /**
     * 找到所有路径:从各个节点出发递归找到所有路径
     *
     * @param arr
     * @param n
     * @param list
     */
    private static void findAllPaths(boolean[][] arr, int n, HashMap<Integer, List<HashSet<Integer>>> list) {
        for (int i = 1; i <= n; i++) {
            getNext(arr, i, list, new HashSet<>());
        }
    }

    /**
     * 递归获取路径
     *
     * @param arr
     * @param index
     * @param list
     * @param set
     */
    private static void getNext(boolean[][] arr, int index, HashMap<Integer, List<HashSet<Integer>>> list, HashSet<Integer> set) {
        for (int i = 1; i < arr.length; i++) {
            if (arr[index][i]) {
                if (set.contains(i)) {
                    list.computeIfAbsent(set.size(), k -> new ArrayList<>());
                    list.get(set.size()).add(new HashSet<>(set));
                } else {
                    set.add(i);
                    getNext(arr, i, list, set);
                    set.remove(i);
                }
            }
        }
    }

    /**
     * 求出最大利润
     *
     * @param list
     * @param n
     * @return
     */
    private static int getMaxProfile(HashMap<Integer, List<HashSet<Integer>>> list, int n) {
        int k = n / 2;
        int m = n - k;
        int max = 0;
        List<HashSet<Integer>> empty = new ArrayList<>(0);
        while (k > 1 && m < n) {
            List<HashSet<Integer>> list1 = list.getOrDefault(k, empty);
            List<HashSet<Integer>> list2 = list.getOrDefault(m, empty);
            if (list1.isEmpty() || list2.isEmpty()) {
                k--;
                m++;
                continue;
            }
            for (HashSet<Integer> s1 : list1) {
                // 求 s1 的补集 s2
                HashSet<Integer> s2 = new HashSet<>();
                for (int i = 1; i <= n; i++) {
                    if (!s1.contains(i)) {
                        s2.add(i);
                    }
                }
                // 找 s2 是否存在
                if (list2.contains(s2)) {
                    int profile = (k - 1) * (m - 1);
                    if (profile > max) {
                        max = profile;
                    }
                }
            }
            k--;
            m++;
        }
        return max;
    }
}
目录
相关文章
|
算法 搜索推荐
2015年华科834复试笔试题
2015年华科834复试笔试题
|
算法 调度 数据库
2016年华科834复试笔试题
2016年华科834复试笔试题
|
算法
牛客网———公务员面试
牛客网———公务员面试
202 0
|
架构师 程序员
入行五年的普通程序员,能赚100万吗?
入行五年的普通程序员,能赚100万吗? 你觉得可能吗?
入行五年的普通程序员,能赚100万吗?
|
算法 搜索推荐 前端开发
金九银十跳槽季——七种排序算法
金九银十跳槽季——七种排序算法
|
程序员 微服务
佛系程序员的月薪五万指南
大师:很简单,我这里有一份佛系月薪 5 万指南,我看你骨骼清奇、脑门光亮,一看就是将要大富大贵之人,这份指南可以助你快速实现小目标!
19266 39
大厂面试真题详解:买卖股票的最佳时机
大厂面试真题详解:买卖股票的最佳时机
大厂面试真题详解:买卖股票的最佳时机
|
算法 Java
又是一年的校招季,过来人给你讲几句肺腑之言
阅读本文大概需要 10 分钟。 转眼间又到了六月底。马上就要迎来新一年的秋季校园招聘了。这对很多即将毕业的,想要从事互联网行业的同学来说,都是非常重要的一段时间。 在这期间,很多互联网公司将陆续开始校园招聘,招聘对于很多公司来说都是非常重要的,它是为公司储备优秀人才的一个重要的活动。
|
程序员
程序员月薪12k被老板逼走,换到国企月薪20k,还5点下班!
211,985学校本科毕业5年,UI,上一家创业公司12k,每天被老板嫌弃做得不好,加班不够多。   换了一家国企,工作轻松,5点多下班,月薪有20k。什么阿里腾讯我都不想去了   只能说太爽了,感谢前老板逼我走。
1948 0