首页 > 其他分享 >ABC334F Christmas Present

ABC334F Christmas Present

时间:2024-01-31 22:25:20浏览次数:27  
标签:dist 200005 int double 线段 Present Christmas dp ABC334F

非常好 dp,使我线段树旋转。

原题传送门

分析

首先由于两点之间直线线段最短,我们肯定是希望从头一直送到尾,最后回家。但是有了 \(k\) 的限制,就麻烦了。

考虑一个 dp。我们设 \(dp[i]\) 表示刚送完第 \(i\) 个孩子时所要跑的最短距离。转移的时候我们枚举上一次回家是在送完哪一个孩子之后。设 \(d[i]\) 表示第 \(i\) 个孩子的位置到第 \(i - 1\) 个孩子的位置的距离,\(d_0[i]\) 表示从家到第 \(i\) 个孩子的位置的距离,\(S\) 为 \(d\) 的前缀和,则我们有

\(dp[i] = \min\limits_{i - k \le j < i} \{ dp[j] + d_0[j] + d_0[j + 1] - d[j + 1] + S[i] - S[j]\}\)

即在第 \(j\) 个孩子送完之后回家,后面一直送到 \(i\)。发现这个 dp 可以使用线段树进行优化,具体来说就是到了 \(i\),先把他前面所有 dp 值加上 \(d[i]\),然后区间查最小值作为 \(dp[i]\),再把 \(dp[i] + d_0[i] + d_0[i + 1] - d[i + 1]\) 放到线段树里。这样就搞完了。

听说这个题也可以单调队列搞,反正我现在还没会。

代码

#include <iostream>
#include <iomanip>
#include <math.h>
#define int long long
using namespace std;
int x[200005], y[200005];
double dist(int x1, int y1, int x2, int y2) {
    return sqrt((x2 - x1) * (x2 - x1) + (y2 - y1) * (y2 - y1));
}
double d[200005];
double d0[200005];
double dp[200005];
struct Segment_Tree {
    double mn[800005], tg[800005];
    void tag(int o, double x) { mn[o] += x, tg[o] += x; }
    void pushdown(int o) {
        tag(o << 1, tg[o]);
        tag(o << 1 | 1, tg[o]);
        tg[o] = 0;
    }
    void Add(int o, int l, int r, int L, int R, double x) {
        if (L <= l && r <= R) {
            tag(o, x);
            return;
        }
        pushdown(o);
        int mid = (l + r) >> 1;
        if (L <= mid) 
            Add(o << 1, l, mid, L, R, x);
        if (R > mid)
            Add(o << 1 | 1, mid + 1, r, L, R, x);
        mn[o] = min(mn[o << 1], mn[o << 1 | 1]);
    }
    void Change(int o, int l, int r, int x, double y) {
        if (l == r) {
            mn[o] = y;
            tg[o] = 0;
            return;
        }
        pushdown(o);
        int mid = (l + r) >> 1;
        if (x <= mid) 
            Change(o << 1, l, mid, x, y);
        else 
            Change(o << 1 | 1, mid + 1, r, x, y);
        mn[o] = min(mn[o << 1], mn[o << 1 | 1]);
    }
    double Query(int o, int l, int r, int L, int R) {
        if (L <= l && r <= R) 
            return mn[o];
        int mid = (l + r) >> 1;
        pushdown(o);
        if (R <= mid) 
            return Query(o << 1, l, mid, L, R);
        else if (L > mid) 
            return Query(o << 1 | 1, mid + 1, r, L, R);
        else 
            return min(Query(o << 1, l, mid, L, R), Query(o << 1 | 1, mid + 1, r, L, R));
    }
} seg;
signed main() {
    int n, k;
    cin >> n >> k;
    for (int i = 1; i <= n + 1; i++) {
        cin >> x[i] >> y[i];
        d[i] = dist(x[i - 1], y[i - 1], x[i], y[i]);
        d0[i] = dist(x[1], y[1], x[i], y[i]);
    }
    seg.Change(1, 1, n + 1, 1, 0);
    for (int i = 2; i <= n + 1; i++) {
        seg.Add(1, 1, n + 1, 1, i - 1, d[i]);
        dp[i] = seg.Query(1, 1, n + 1, max(1ll, i - k), i - 1);
        seg.Change(1, 1, n + 1, i, dp[i] + d0[i] + d0[i + 1] - d[i + 1]);
    }
    cout << fixed << setprecision(10) << dp[n + 1] + d0[n + 1];
    return 0;
}

标签:dist,200005,int,double,线段,Present,Christmas,dp,ABC334F
From: https://www.cnblogs.com/forgotmyhandle/p/18000254

相关文章

  • 6-Nameless Representation of Terms
    无名称项deBruijn使用自然数来表示项,而不是字母组成的名称;自然数k表示绑定于第k个λ层的被界定的变量(thevariableboundbythek'thenclosingλ)马世龙版《类型和程序设计语言》使用“囿”来形容这种被界定的关系举例来说:λx.x表示为λ.0λx.λy.x(yx)表示......
  • Adaptively sharing multi-levels of distributed representations in multi-task lea
    期刊:InformationSciences”(Wang等,2022,p.226)计算机科学1区top。2022年题目:“多任务学习中自适应共享多级分布式表示”(pdf)“Adaptivelysharingmulti-levelsofdistributedrepresentationsinmulti-tasklearning”(Wang等,2022,p.226)(pd......
  • ARC151D Binary Representations and Queries
    ARC151DBinaryRepresentationsandQueries题目链接:ARC151DBinaryRepresentationsandQueries非常好思维题。思路首先我们会发现每个操作都是\(\frac{n}{2}\)的\(A_i\),给另外\(\frac{n}{2}\)的\(A_j\)的增加。这题直接去维护每个操作时间复杂度会开心的笑。所以......
  • E - Christmas Color Grid 1
    E-ChristmasColorGrid1https://atcoder.jp/contests/abc334/tasks/abc334_e思路https://www.cnblogs.com/Lanly/p/17923753.htmlCodehttps://atcoder.jp/contests/abc334/submissions/49243194inth,w;bools[1005][1005];intc[1005][1005];//c-classlongl......
  • [论文阅读] Self-conditioned Image Generation via Generating Representations
    Pretitle:Self-conditionedImageGenerationviaGeneratingRepresentationsaccepted:arXiv2023paper:https://arxiv.org/abs/2312.03701code:https://github.com/LTH14/rcgref:https://mp.weixin.qq.com/s/VmyRya2klHpHlJwzMG8JRgref:https://www.zhihu.com/q......
  • No 'Access-Control-Allow-Origin' header is present on the requested resource', 跨
    https://blog.csdn.net/dear_little_bear/article/details/839993911.当请求不在同一域名下的资源文件(ip地址+端口号)时,会报如下错误:“No‘Access-Control-Allow-Origin’headerispresentontherequestedresource.Origin‘http://localhost:8080’isthereforenotall......
  • B - Christmas Trees
    B-ChristmasTreeshttps://atcoder.jp/contests/abc334/tasks/abc334_b 思路对于起始种树点A在[L,R]区间的位置情况,三种A<LA>RA>=L,A<=R Codehttps://atcoder.jp/contests/abc334/submissions/48822474LLa,m,l,r;intmain(){cin>>a>&g......
  • [ABC334E] Christmas Color Grid 1 题解
    题目传送门一道dfs题。先统计出绿连通块数量,然后对于每个红色方块统计涂成绿色方块后会变成多少个连通块。正常涂成绿色后应该会增加一个大小为\(1\)的绿连通块,但若是有不同的绿连通块与其相邻,答案又会减少\(1\)。Code#include<bits/stdc++.h>constlonglongIMX=1......
  • AtCoder Beginner Contest 334 G Christmas Color Grid 2
    洛谷传送门AtCoder传送门考虑相当于把每个标记点的边全部断掉,然后求连通块个数。考虑一条边\((u,v)\)(设\(u<v\))的出现时间,不难发现是\([1,u-1]\cup[u+1,v-1]\cup[v+1,n]\)。于是考虑直接套线段树分治和可撤销并查集。时空复杂度均为\(O(n^2\logn)\)......
  • 题解 ABC334G【Christmas Color Grid 2】
    先求出初始时绿连通块数量。将一个绿色格子染成红色,会改变绿连通块数量,当且仅当这个绿色格子是孤点或割点。如果是孤点,会使得绿连通块数量减少一;如果是割点,会使得绿连通块数量增加它所在的点双数量减一。根据上述规则可以求出每个绿色格子染红后的绿连通块数量,求平均值即可。时......