博客
关于我
2015蓝桥杯java决赛C组 试题解析
阅读量:640 次
发布时间:2019-03-14

本文共 871 字,大约阅读时间需要 2 分钟。

蓝桥村的居民集会问题需要找到最佳的集会地点,使得所有家庭的路程开销最小。我们可以通过动态规划来解决这个问题,维护一个数组dp,其中dp[i]表示前i个家庭选择一个集会地点的最小开销。初始化时,dp[0]为0,其他为无穷大。遍历每个家庭,更新dp[i]为min(dp[i-j] + j * ti),其中j是家庭i的位置。最终dp[n]即为所求。

Java代码如下:

public class Main {    public static void main(String[] args) {        Scanner input = new Scanner(System.in);        int n = input.nextInt();        int L = input.nextInt();        int[] di = new int[n];        int[] ti = new int[n];        for (int i = 0; i < n; i++) {            di[i] = input.nextInt();            ti[i] = input.nextInt();        }        int[] dp = new int[n + 1];        Arrays.fill(dp, Integer.MAX_VALUE);        dp[0] = 0;        for (int i = 1; i <= n; i++) {            for (int j = 1; j <= i && j <= L - di[i-1]; j++) {                dp[i] = Math.min(dp[i - j] + j * ti[i - 1], dp[i]);            }        }        System.out.println(dp[n]);    }}

最终的路程开销和为:20

转载地址:http://wmulz.baihongyu.com/

你可能感兴趣的文章
Objective-C实现SinglyLinkedList单链表算法(附完整源码)
查看>>
Objective-C实现SizeBalancedTree大小平衡树(附完整源码)
查看>>
Objective-C实现skew heap倾斜堆算法(附完整源码)
查看>>
Objective-C实现Skip List跳表算法(附完整源码)
查看>>
Objective-C实现slack message松弛消息算法(附完整源码)
查看>>
Objective-C实现SlopeOne算法(附完整源码)
查看>>
Objective-C实现slow sort慢排序算法(附完整源码)
查看>>
Objective-C实现smo算法(附完整源码)
查看>>
Objective-C实现SNTP协议(附完整源码)
查看>>
Objective-C实现sobel filter索贝尔过滤器算法(附完整源码)
查看>>
Objective-C实现Sobel算子(附完整源码)
查看>>
Objective-C实现Sobel算子(附完整源码)
查看>>
Objective-C实现sobel边缘检测算法(附完整源码)
查看>>
Objective-C实现sock merchant袜子商人问题算法(附完整源码)
查看>>
Objective-C实现Softmax 函数的实现算法(附完整源码)
查看>>
Objective-C实现softmax函数功能(附完整源码)
查看>>
Objective-C实现stooge sort臭皮匠排序算法(附完整源码)
查看>>
Objective-C实现strand sor链排序排序算法(附完整源码)
查看>>
Objective-C实现strassen matrix multiplication施特拉森矩阵乘法算法(附完整源码)
查看>>
Objective-C实现StringSearch字符串搜索算法(附完整源码)
查看>>