深海机器人(cogs 742)

2023-11-04 22:50
文章标签 机器人 cogs 深海 742

本文主要是介绍深海机器人(cogs 742),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

«问题描述:
深海资源考察探险队的潜艇将到达深海的海底进行科学考察。潜艇内有多个深海机器
人。潜艇到达深海海底后,深海机器人将离开潜艇向预定目标移动。深海机器人在移动中还
必须沿途采集海底生物标本。沿途生物标本由最先遇到它的深海机器人完成采集。每条预定
路径上的生物标本的价值是已知的,而且生物标本只能被采集一次。本题限定深海机器人只
能从其出发位置沿着向北或向东的方向移动,而且多个深海机器人可以在同一时间占据同一
位置。
«编程任务:
用一个P´Q 网格表示深海机器人的可移动位置。西南角的坐标为(0,0),东北角的坐

标为 (Q,P)。

给定每个深海机器人的出发位置和目标位置,以及每条网格边上生物标本的价值。计算
深海机器人的最优移动方案,使深海机器人到达目的地后,采集到的生物标本的总价值最高。
«数据输入:
由文件shinkai.in提供输入数据。文件的第1 行为深海机器人的出发位置数a,和目的地
数b,第2 行为P和Q 的值。接下来的P+1 行,每行有Q 个正整数,表示向东移动路径上
生物标本的价值,行数据依从南到北方向排列。再接下来的Q+1 行,每行有P 个正整数,
表示向北移动路径上生物标本的价值,行数据依从西到东方向排列。接下来的a行,每行有
3 个正整数k,x,y,表示有k个深海机器人从(x,y)位置坐标出发。再接下来的b行,每行有3
个正整数r,x,y,表示有r个深海机器人可选择(x,y)位置坐标作为目的地。
«结果输出:
程序运行结束时,将采集到的生物标本的最高总价值输出到文件shinkai.out中。

shinkai.in
1 1
2 2
1 2
3 4
5 6
7 2
8 10
9 3
2 0 0

2 2 2

shinkai.out

42

1<=P,Q<=15 1<=a,b<=10

/*费用流。因为每条边可以随便走,并且只能获利一次,所以把每条边拆成两条边,一条容量为1,费用为w,另一条容量无限,费用为0。注意体面中的x,y坐标比较坑。 
*/
#include<iostream>
#include<cstdio>
#include<queue>
#define N 1010
#define inf 1000000000
using namespace std;
int head[N],dis[N],inq[N],fa[N],a,b,P,Q,S,T,cnt=1;
struct node{int v,f,w,pre;}e[N*10];
queue<int> q;
void add(int u,int v,int f,int w){e[++cnt].v=v;e[cnt].f=f;e[cnt].w=w;e[cnt].pre=head[u];head[u]=cnt;e[++cnt].v=u;e[cnt].f=0;e[cnt].w=-w;e[cnt].pre=head[v];head[v]=cnt;
}
bool spfa(){for(int i=0;i<=T;i++) dis[i]=inf;dis[S]=0;q.push(S);while(!q.empty()){int u=q.front();q.pop();inq[u]=0;for(int i=head[u];i;i=e[i].pre)if(e[i].f&&dis[e[i].v]>dis[u]+e[i].w){dis[e[i].v]=dis[u]+e[i].w;fa[e[i].v]=i;if(!inq[e[i].v]){inq[e[i].v]=1;q.push(e[i].v);}}}return dis[T]!=inf;
}
int updata(){int i=fa[T],x=inf;while(i){x=min(x,e[i].f);i=fa[e[i^1].v];}i=fa[T];while(i){e[i].f-=x;e[i^1].f+=x;i=fa[e[i^1].v];}return x*dis[T];
}
int id(int x,int y){return (x-1)*Q+y;}
int main(){freopen("shinkai.in","r",stdin);freopen("shinkai.out","w",stdout);scanf("%d%d%d%d",&a,&b,&P,&Q);P++;Q++;S=0;T=P*Q+1;for(int i=1;i<=P;i++)for(int j=1;j<Q;j++){int x;scanf("%d",&x);add(id(i,j),id(i,j+1),1,-x);add(id(i,j),id(i,j+1),inf,0);}for(int j=1;j<=Q;j++)for(int i=1;i<P;i++){int x;scanf("%d",&x);add(id(i,j),id(i+1,j),1,-x);add(id(i,j),id(i+1,j),inf,0);}for(int i=1;i<=a;i++){int k,x,y;scanf("%d%d%d",&k,&x,&y);add(S,id(x+1,y+1),k,0);}for(int i=1;i<=b;i++){int k,x,y;scanf("%d%d%d",&k,&x,&y);add(id(x+1,y+1),T,k,0);}int minv=0;while(spfa())minv+=updata();printf("%d",-minv);return 0;
}

 

转载于:https://www.cnblogs.com/harden/p/6711190.html

这篇关于深海机器人(cogs 742)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/345717

相关文章

Python基于火山引擎豆包大模型搭建QQ机器人详细教程(2024年最新)

《Python基于火山引擎豆包大模型搭建QQ机器人详细教程(2024年最新)》:本文主要介绍Python基于火山引擎豆包大模型搭建QQ机器人详细的相关资料,包括开通模型、配置APIKEY鉴权和SD... 目录豆包大模型概述开通模型付费安装 SDK 环境配置 API KEY 鉴权Ark 模型接口Prompt

基于树梅派的视频监控机器人Verybot

最近这段时间做了一个基于树梅派 ( raspberry pi ) 的视频监控机器人平台 Verybot ,现在打算把这个机器人的一些图片、视频、设计思路进行公开,并且希望跟大家一起研究相关的各种问题,下面是两张机器人的照片:         图片1:                   图片2                    这个平台的基本组成是:

【机器人工具箱Robotics Toolbox开发笔记(二十)】机器人工具箱SerialLink I类函数参数说明

机器人工具箱中的SerialLink表示串联机器人型机器人的具体类。该类使用D-H参数描述,每个关节一组。SerialLink I类包含的参数如表1所示。 表1 SerialLink I类参数 参  数 意    义 参  数 意    义 plot 显示机器人的图形表示 jacobn 工具坐标系中的雅可比矩阵 plot3D 显示机器人3D图形模型 Jacob_dot

机器人助力上下料搬运,加速仓库转运自动化

近年来,国内制造业领域掀起了一股智能化改造的浪潮,众多工厂纷纷采纳富唯智能提供的先进物流解决方案,这一举措显著优化了生产流程,实现了生产效率的飞跃式增长。得益于这些成功案例,某信息技术服务企业在工厂智能物流建设的进程中,也选择了与富唯智能合作。 为了应对日益增长的物料搬运需求,匹配成品输出节拍,该公司引入了富唯智能复合机器人AMR与搬运机器人AGV,实现了仓库成品搬运自动化,大幅减少人工

【最新华为OD机试E卷-支持在线评测】机器人活动区域(100分)多语言题解-(Python/C/JavaScript/Java/Cpp)

🍭 大家好这里是春秋招笔试突围 ,一枚热爱算法的程序员 ✨ 本系列打算持续跟新华为OD-E/D卷的三语言AC题解 💻 ACM金牌🏅️团队| 多次AK大厂笔试 | 编程一对一辅导 👏 感谢大家的订阅➕ 和 喜欢💗 🍿 最新华为OD机试D卷目录,全、新、准,题目覆盖率达 95% 以上,支持题目在线评测,专栏文章质量平均 94 分 最新华为OD机试目录: https://blog.

Dify.ai:部署自己的 AI 应用、知识库机器人,简单易用

Dify.ai:部署自己的 AI 应用、知识库机器人,简单易用 今天,来分享下 Dify.AI 这个产品,一句话介绍:可供普通人简单易用的部署生成出一个 AI 应用。这是一种使用人工智能技术来帮助团队开发和运营 AI 应用的工具。 什么是 Dify.ai Dify.ai 是一个易于使用的 LLMOps 平台,旨在帮助更多的人创建可持续的、AI 原生的应用。通过对各种应用类型的可视化编排,Di

机器人可能会在月球上提供帮助

登月是我们这个时代最具标志性的事件之一,这可能还算轻描淡写了:这是我们迄今为止在物理上探索得最远的一次。我听过一些当时的老广播,它们可以让你想象出这次航行的重要性。 现在,研究人员表示,我们可能很快就能重返月球,甚至可能很快就会有人类任务前往火星。 火星。艺术家:NASA 这次会有什么不同呢? 有一点是确定的:机器人将大力协助—— 非常多。 在麻省理工学院,我们的一些团队正在开发突破性的

【人工智能/机器学习/机器人】数学基础-学习笔记

函数 奇偶性: 偶函数: f ( − x ) = f ( x ) f(-x)=f(x) f(−x)=f(x)     y轴对称 f ( x ) = x 2 f(x)=x^2 f(x)=x2     f ( − x ) = ( − x ) 2 = x 2 = f ( x ) f(-x)=(-x)^2=x^2=f(x) f(−x)=(−x)2=x2=f(x) 奇函数: f ( − x )

全国机器人大赛 Robocon 常州工学院团队首战国三

全国机器人大赛 Robocon 常州工学院团队首战国三 通宵7天7夜,常州工学院RC团队,首次闯入全国机器人大赛国赛,并成功得分! 不同于老牌强队,常州工学院(下面用"常工"代替)的这只队伍,大多数成员由大一组成,核心岗位由一些大二各个专业基础最为扎实的学生担任。 7月7日,19:26分。卡在报道的最后10分钟,由在团队项管和电控成功领队签到,光电Robot成为最近几年唯一一只冲入Roboc

论文速读|利用局部性提高机器人操作的样本效率

项目地址:SGRv2  本文提出了SGRv2,一个系统的视觉运动政策框架,通过整合动作局部性提高了样本效率。在多个模拟和真实世界环境中进行的广泛评估表明,SGRv2在数据有限的情况下表现出色,并且在不同的控制模式下保持一致的性能。未来的工作可以进一步探索将扩散政策与局部性框架结合,以增强在现实世界中的性能,并扩展泛化测试的范围。 论文初读: