洛谷 P3133 [USACO16JAN] Radio Contact G

题目描述

FJ 失去了他最喜欢的牛铃,而 Bessie 已经同意帮助他找到它!他们用不同的路径搜索农场,通过无线电保持联系。

不幸的是,无线电中的电池电量不足,所以他们设法尽可能保持两者位置的距离最小,以节省电量。

FJ 从位置(fx​,fy​) 开始,并计划遵循由 N 步组成的路径.Bessie 从位置 (bx​,by​) 开始,并遵循由 M 步组成的路径。每个步骤都是 N(北),E(东),S(南),或W(西)。其中,东方向为 x 轴正方向,北方向为 y 轴正方向。两个路径可以经过相同的点。

在每个时间段,FJ 可以不移动,也可以沿着他的道路前进一步。无论哪个方向恰好在下一个(假设他还没有到达他的路径的最后位置)。Bessie 可以做出类似的选择。

在每个时间点(不包括从初始位置开始的第一步),他们的无线电消耗的能量等于它们之间距离的平方。

请帮助 FJ 和 Bessie 计划行动策略,使双方达到各自终点时,最大限度地减少消耗的能量总量。输出所消耗的最小的能量。

输入格式

第一行两个整数 N 和 M (1≤N,M≤1000)。

第二行两个整数 fx​ 和 fy​。

第三行两个整数 bx​ 和 by​ (0≤fx​,fy​,bx​,by​≤1000)。

下一行为一个长度为 N 的字符串,描述 FJ 的路径。

最后一行为一个长度 M 的字符串,描述 Bessie 的路径。

输出格式

共一行一个整数,表示最小能量。

显示翻译

题意翻译

输入输出样例

输入 #1复制

复制代码
2 7
3 0
5 0
NN
NWWWWWN

输出 #1复制

复制代码
28
cpp 复制代码
#include<bits/stdc++.h>
using namespace std;
const int N=1010;
int f[N][N];
int n,m;
struct node{
    int x,y;
}a[N],b[N];
int dist(int i,int j)
{
    return (a[i].x-b[j].x)*(a[i].x-b[j].x)+
            (a[i].y-b[j].y)*(a[i].y-b[j].y);
}
int main()
{
    cin>>n>>m;
    cin>>a[0].x>>a[0].y;
    cin>>b[0].x>>b[0].y;
    for(int i=1;i<=n;i++)
    {
        char ch;
        cin>>ch;
        if(ch=='N')
        {
            a[i]={a[i-1].x,a[i-1].y+1};
        }else if(ch=='E')
        {
            a[i]={a[i-1].x+1,a[i-1].y};
        }else if(ch=='W')
        {
            a[i]={a[i-1].x-1,a[i-1].y};
        }else
        {
            a[i]={a[i-1].x,a[i-1].y-1};
        }
    }

    for(int i=1;i<=m;i++)
    {
        char ch;
        cin>>ch;
        if(ch=='N')
        {
            b[i]={b[i-1].x,b[i-1].y+1};
        }else if(ch=='E')
        {
            b[i]={b[i-1].x+1,b[i-1].y};
        }else if(ch=='W')
        {
            b[i]={b[i-1].x-1,b[i-1].y};
        }else
        {
            b[i]={b[i-1].x,b[i-1].y-1};
        }
    }
    //初始化
    for(int i=1;i<=n;i++)
    {
        f[i][0]=f[i-1][0]+dist(i,0);
    }
    for(int j=1;j<=m;j++)
    {
        f[0][j]=f[0][j-1]+dist(0,j);
    }
    for(int i=1;i<=n;i++)
    {
        for(int j=1;j<=m;j++)
        {
            f[i][j]=min(f[i-1][j-1],min(f[i-1][j],f[i][j-1]))+dist(i,j);
        }
    }
    cout<<f[n][m];
    return 0;
}
相关推荐
weixin_513449962 小时前
PCA、SVD 、 ICP 、kd-tree算法的简单整理总结
c++·人工智能·学习·算法·机器人
code_pgf2 小时前
Qwen2.5-VL 算法解析
人工智能·深度学习·算法·transformer
Code-keys3 小时前
Android Codec2 Filter 算法模块开发指南
android·算法·音视频·视频编解码
无忧智库3 小时前
低空经济新基建:构建低空飞行大数据中心与行业应用算法工厂的全景式蓝图(WORD)
算法
闻缺陷则喜何志丹4 小时前
【背包 组合】P7552 [COCI 2020/2021 #6] Anagramistica|普及+
c++·算法·背包·洛谷·组合
锅挤4 小时前
数据结构复习(第五章):树与二叉树
数据结构
小章UPUP4 小时前
2026年第十六届MathorCup数学应用挑战赛D题国奖思路
算法
hssfscv5 小时前
软件设计师下午试题四——C语言(N皇后问题、分治、动态规划)
c语言·算法·动态规划
lolo大魔王5 小时前
Go语言的反射机制
开发语言·后端·算法·golang