zoukankan      html  css  js  c++  java
  • poj1661

    dp

    View Code
    #include <iostream>
    #include
    <cstdio>
    #include
    <cstdlib>
    #include
    <cstring>
    #include
    <algorithm>
    using namespace std;

    #define maxn 1005

    struct Plat
    {
    int l, r, h, lt, rt;
    } plat[maxn];

    int n, m, cx, cy;

    bool operator <(const Plat &a, const Plat &b)
    {
    return a.h > b.h;
    }

    void input()
    {
    scanf(
    "%d%d%d%d", &n, &cx, &cy, &m);
    plat[
    0].l = plat[0].r = cx;
    plat[
    0].h = cy;
    for (int i = 1; i <= n; i++)
    {
    scanf(
    "%d%d%d", &plat[i].l, &plat[i].r, &plat[i].h);
    if (plat[i].l > plat[i].r)
    swap(plat[i].l, plat[i].r);
    }
    }

    void work()
    {
    int j;
    int ans = 0x3f3f3f3f;
    for (int i = 0; i <= n; i++)
    plat[i].lt
    = plat[i].rt = 0x3f3f3f3f;
    plat[
    0].lt = plat[0].rt = 0;
    for (int i = 0; i <= n; i++)
    {
    for (j = i + 1; j <= n; j++)
    {
    if (plat[i].h - plat[j].h > m)
    break;
    if (plat[i].h == plat[j].h)
    continue;
    if (plat[i].l <= plat[j].r && plat[i].l >= plat[j].l)
    {
    plat[j].lt
    = min(plat[i].h - plat[j].h + plat[i].lt + abs(
    plat[i].l
    - plat[j].l), plat[j].lt);
    plat[j].rt
    = min(plat[i].h - plat[j].h + plat[i].lt + abs(
    plat[i].l
    - plat[j].r), plat[j].rt);
    break;
    }
    }
    if (j > n && plat[i].h <= m)
    ans
    = min(ans, plat[i].lt + plat[i].h);
    for (j = i + 1; j <= n; j++)
    {
    if (plat[i].h - plat[j].h > m)
    break;
    if (plat[i].h == plat[j].h)
    continue;
    if (plat[i].r <= plat[j].r && plat[i].r >= plat[j].l)
    {
    plat[j].lt
    = min(plat[i].h - plat[j].h + plat[i].rt + abs(
    plat[i].r
    - plat[j].l), plat[j].lt);
    plat[j].rt
    = min(plat[i].h - plat[j].h + plat[i].rt + abs(
    plat[i].r
    - plat[j].r), plat[j].rt);
    break;
    }
    }
    if (j > n && plat[i].h <= m)
    ans
    = min(ans, plat[i].rt + plat[i].h);
    }
    printf(
    "%d\n", ans);
    }

    int main()
    {
    //freopen("t.txt", "r", stdin);
    int t;
    scanf(
    "%d", &t);
    while (t--)
    {
    input();
    sort(plat, plat
    + n + 1);
    work();
    }
    return 0;
    }

  • 相关阅读:
    Intel CPU编号详解
    matplotlib(二)——matplotlib控制坐标轴第一个刻度到原点距离
    matplotlib(一)——matplotlib横轴坐标密集字符覆盖
    博客园定制页面(五)——使用自定义JS脚本(公告栏显示时间)
    PyCharm(二)——PyCharm打开本地项目不显示项目文件
    nohup命令
    URL是如何解析的
    Python 得到主机字节序
    Python 得到ISP地址
    亚马逊s3上传大文件Python
  • 原文地址:https://www.cnblogs.com/rainydays/p/2082592.html
Copyright © 2011-2022 走看看