news 2026/4/30 10:31:47

打卡信奥刷题(2684)用C++实现信奥题 P2994 [USACO10OCT] Dinner Time S

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
打卡信奥刷题(2684)用C++实现信奥题 P2994 [USACO10OCT] Dinner Time S

P2994 [USACO10OCT] Dinner Time S

题目描述

农场主约翰的N NN1 ≤ N ≤ 10 3 1 \le N \le 10 ^ 31N103)头奶牛被编号为1 ∼ N 1 \sim N1N,它们正在保加利亚参加 IOI。奶牛们喜欢保加利亚的太阳并享受着它们的假日,一切看起来都没问题。

变化发生在晚餐时间前后。这家餐馆很小,只有M MM1 ≤ M ≤ N 1 \le M \le N1MN)个座位,编号为1 ∼ M 1 \sim M1M。每头牛从一个位置C X i CX_iCXiC Y i CY_iCYi进入餐馆(− 10 6 ≤ C X i ≤ 10 6 , − 10 6 ≤ C Y i ≤ 10 6 -10 ^ 6 \le CX_i \le 10 ^ 6,-10 ^ 6 \le CY_i \le 10 ^ 6106CXi106,106CYi106);座位可以在S X j SX_jSXjS Y j SY_jSYj找到(− 10 6 ≤ S X j ≤ 10 6 , − 10 6 ≤ S Y j ≤ 10 6 -10 ^ 6 \le SX_j \le10 ^ 6,-10 ^ 6\le SY_j\le 10 ^ 6106SXj106,106SYj106)。

奶牛有一种非常有效的(尽管很原始)方法把自己分配到座位上。一旦某只奶牛确定她会先到某个座位上,她就会尽快赶到那里(所有的奶牛都跑得一样快)。

农场主约翰的奶牛和所有获奖的奶牛一样,跳过座位、桌子或其他奶牛都没有问题,因此它们可以直线奔跑。当多头牛可以同时到达一个座位时,最老的牛(在输入数据中出现得更早的牛)获得座位。当一头牛可以第一个到达多个座位时,她也会选择在输入中最早出现的座位。

一些奶牛将不能吃晚饭,这些吃不到饭的饥饿的奶牛正集体计划偷农场主约翰自己的食物。农场主约翰想要一份他应该提防的奶牛名单。(如果没有饥饿的奶牛,则输出0 00)。你能帮他吗?

注:在计算中可能会有超过32 3232位整数范围但在64 6464位整数范围内的数。


输入格式

第一行:两个空格分隔的整数:N NNM MM

2 ∼ N + 1 2 \sim N + 12N+1行:第i + 1 i+1i+1行包含两个空格分隔的整数:C X i CX_iCXiC Y i CY_iCYi

N + 2 ∼ N + M + 1 N+2 \sim N+M+1N+2N+M+1行:行j + N + 1 j+N+1j+N+1包含两个空格分隔的整数:S X j SX_jSXjS Y j SY_jSYj


输出格式

1 11行到第( N − M ) (N-M)(NM)行:第i ii行包含农场主约翰应该提防的第i ii头牛的编号。奶牛的编号应递增排序。

输入输出样例 #1

输入 #1

2 1 0 1 1 0 1 10

输出 #1

2

C++实现

#include<bits/stdc++.h>usingnamespacestd;constintmaxn=1000+5;//为了方便定义数组,直接把数据范围控制好longlonga[maxn],b[maxn],c,d;//a,b表示奶牛计入房间位置,c,d表示座位位置intflag[maxn];//用来标记那些奶牛已经有座位了intpos;//记录有座位的奶牛编号intmain(){intn,m;cin>>n>>m;for(inti=1;i<=n;i++)cin>>a[i]>>b[i];for(intj=1;j<=m;j++){cin>>c>>d;longlongdis=0;longlongmindis=1e15;for(inti=1;i<=n;i++){if(flag[i]==1)continue;//已有座位,直接跳过dis=(a[i]-c)*(a[i]-c)+(b[i]-d)*(b[i]-d);//计算距离,用勾股定理if(dis<mindis){mindis=dis;//重新赋最小值pos=i;//标记}}flag[pos]=1;//标记,已有座位}if(n==m){cout<<0;return0;}for(inti=1;i<=n;i++){if(flag[i])continue;cout<<i<<endl;}return0;}

后续

接下来我会不断用C++来实现信奥比赛中的算法题、GESP考级编程题实现、白名单赛事考题实现,记录日常的编程生活、比赛心得,感兴趣的请关注,我后续将继续分享相关内容

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/30 11:20:07

代谢组学分析新视野:MetaboAnalystR深度探索指南

代谢组学分析新视野&#xff1a;MetaboAnalystR深度探索指南 【免费下载链接】MetaboAnalystR R package for MetaboAnalyst 项目地址: https://gitcode.com/gh_mirrors/me/MetaboAnalystR MetaboAnalystR作为基于R语言构建的综合性代谢组学分析平台&#xff0c;为研究人…

作者头像 李华
网站建设 2026/4/25 3:41:22

SMAPI模组加载器终极指南:10个步骤带你从新手到专家

SMAPI模组加载器终极指南&#xff1a;10个步骤带你从新手到专家 【免费下载链接】SMAPI The modding API for Stardew Valley. 项目地址: https://gitcode.com/gh_mirrors/smap/SMAPI 星露谷物语SMAPI模组加载器是每个模组玩家必备的核心工具&#xff0c;它能帮你轻松管…

作者头像 李华
网站建设 2026/4/28 21:43:47

Docker Swarm网络管理【20260113】

文章目录 一、Swarm 网络核心类型(新手友好版) 二、Swarm 集群的默认网络(自动创建) 1. `ingress` 网络 2. `docker_gwbridge` 网络 三、自定义 Overlay 网络(实战核心) 1. 创建自定义 Overlay 网络 2. 给服务绑定自定义 Overlay 网络 3. 验证服务间通信(核心:内置服务…

作者头像 李华
网站建设 2026/5/1 9:26:20

手势追踪技术解析:MediaPipe Hands原理详解

手势追踪技术解析&#xff1a;MediaPipe Hands原理详解 1. 引言&#xff1a;AI 手势识别与追踪的技术演进 随着人机交互方式的不断演进&#xff0c;传统输入设备&#xff08;如鼠标、键盘&#xff09;已无法满足日益增长的沉浸式体验需求。从VR/AR到智能车载系统&#xff0c;…

作者头像 李华
网站建设 2026/4/25 18:08:19

手部姿态估计在VR游戏中的应用:MediaPipe Hands实践

手部姿态估计在VR游戏中的应用&#xff1a;MediaPipe Hands实践 1. 引言&#xff1a;手势交互如何重塑VR体验 1.1 VR交互的演进与挑战 虚拟现实&#xff08;VR&#xff09;技术正从“视觉沉浸”向“全感官交互”演进。传统手柄操控虽精准&#xff0c;但缺乏自然感和直觉性。…

作者头像 李华
网站建设 2026/4/25 19:28:22

AI自动打码案例:新闻图片隐私处理

AI自动打码案例&#xff1a;新闻图片隐私处理 1. 引言&#xff1a;AI 人脸隐私卫士 - 智能自动打码 在新闻报道、公共安全监控、社交媒体内容发布等场景中&#xff0c;图像中的个人面部信息往往涉及敏感隐私。传统的人工打码方式效率低下、成本高昂&#xff0c;且难以应对多人…

作者头像 李华