博客
关于我
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/

你可能感兴趣的文章
Notepad++在线和离线安装JSON格式化插件
查看>>
notepad++最详情汇总
查看>>
notepad如何自动对齐_notepad++怎么自动排版
查看>>
Notification 使用详解(很全
查看>>
NotImplementedError: Cannot copy out of meta tensor; no data! Please use torch.nn.Module.to_empty()
查看>>
Now trying to drop the old temporary tablespace, the session hangs.
查看>>
nowcoder—Beauty of Trees
查看>>
np.arange()和np.linspace()绘制logistic回归图像时得到不同的结果?
查看>>
np.power的使用
查看>>
NPM 2FA双重认证的设置方法
查看>>
npm build报错Cannot find module ‘webpack/lib/rules/BasicEffectRulePlugin‘解决方法
查看>>
npm build报错Cannot find module ‘webpack‘解决方法
查看>>
npm ERR! ERESOLVE could not resolve报错
查看>>
npm ERR! Unexpected end of JSON input while parsing near ‘...“:“^1.2.0“,“vue-html-‘ npm ERR! A comp
查看>>
npm error Missing script: “server“npm errornpm error Did you mean this?npm error npm run serve
查看>>
npm error MSB3428: 未能加载 Visual C++ 组件“VCBuild.exe”。要解决此问题,1) 安装
查看>>
npm install CERT_HAS_EXPIRED解决方法
查看>>
npm install digital envelope routines::unsupported解决方法
查看>>
npm install 卡着不动的解决方法
查看>>
npm install 报错 EEXIST File exists 的解决方法
查看>>