news 2026/4/16 10:55:04

打卡信奥刷题(2525)用C++实现信奥 P2013 无线电测向

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
打卡信奥刷题(2525)用C++实现信奥 P2013 无线电测向

P2013 无线电测向

题目描述

有天线定位装置的船能通过接收当地灯塔信号来确定自己的位置。每个灯塔固定在已知点上并发出特有的信号。当船检测到信号,它可通过旋转天线直到信号达到最大强度。这样就可确定自身与该灯塔的位置关系。只要接收到两个灯塔的信息,就有可能确定船当前的位置。

编程任务:通过一对灯塔信息来确定船的位置。

灯塔和船的位置被确定在一个直角坐标系内。xxx轴正向指向东,yyy轴正向指向北。船的航行路线从正北开始按顺时针用度表示。北是0∘0^\circ0,东是90∘90^\circ90,南是180∘180^\circ180,西是270∘270^\circ270。灯塔与船的位置关系用相对于船的航行方向顺时针用度表示。

输入格式

文件的第一行是一个整数,表示灯塔的数目NNN。以下NNN行,每行表示一个灯塔,为灯塔名称,xxx坐标和yyy坐标。它们都用空格隔开。

灯塔信息下面是船的信息包括三行,一行是船的方向,其余两行是所接收到的灯塔信号。

具体如下:

输入数据数据的含义
方向船的航行方向
名称111,角度111第一个灯塔信息的名称,灯塔的方位
名称222,角度222第二个灯塔信息的名称,灯塔的方位

灯塔的方位为船与灯塔所在的直线与船的航行方向的夹角(从船的航行方向开始顺时针)。222个数据用空格隔开。

输出格式

输出船的位置(精确到222位小数)。如果无法确定船的位置,应输出NO ANSWER(不能使用小写)。

输入输出样例 #1

输入 #1

5 a 1 5 b 1 1000 c 2 4 d 51 60 e 153 79 30 e 160 d 210

输出 #1

160.83 123.41

说明/提示

对于100%100 \%100%的数据,1≤N≤301 \le N \le 301N30,灯塔名称是202020个以下的字母。

C++实现

#include<bits/stdc++.h>#definepiipair<int,int>usingnamespacestd;constdoublepi=3.1415926535;// 建议选取较高精度intn;map<string,pii>mp;intmain(){cin>>n;for(inti=1;i<=n;++i){intx,y;string name;cin>>name>>x>>y;mp.insert(make_pair(name,make_pair(x,y)));}string s1,s2;doubleangleShip,angle1,angle2;cin>>angleShip;angleShip=90-angleShip;// 转化为与 x 轴的夹角cin>>s1>>angle1;cin>>s2>>angle2;doublex1=mp[s1].first,y1=mp[s1].second;doublex2=mp[s2].first,y2=mp[s2].second;angle1=1.0*(angleShip-angle1)*pi/180;// x 轴夹角转换与弧度制转换angle2=1.0*(angleShip-angle2)*pi/180;if(angle1==angle2){// 判断夹角cout<<"NO ANSWER";return0;}doublek1=tan(angle1),k2=tan(angle2);// 计算斜率,传参弧度制doublex=(y2-y1-k2*x2+k1*x1)/(k1-k2);// 套上述结论doubley=k1*(x-x1)+y1;printf("%.2lf %.2lf",x,y);// 保留两位小数return0;}

后续

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

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

从 “道、法、术、器、势“ 看量化交易:A 股实战指南

你有没有发现&#xff0c;炒股就像开车&#xff1f;有人靠直觉猛踩油门&#xff0c;有人靠导航规划路线。量化交易就像给车装了智能驾驶系统&#xff0c;用一套清晰的逻辑帮你在市场里稳当行驶。今天咱们用老祖宗的 "道、法、术、器、势" 五个字&#xff0c;把量化交…

作者头像 李华
网站建设 2026/4/16 10:05:25

Galaxy UI组件库终极指南:快速构建精美界面的完整教程

Galaxy UI组件库终极指南&#xff1a;快速构建精美界面的完整教程 【免费下载链接】galaxy &#x1f680; 3000 UI elements! Community-made and free to use. Made with either CSS or Tailwind. 项目地址: https://gitcode.com/gh_mirrors/gal/galaxy Galaxy UI组件库…

作者头像 李华
网站建设 2026/4/11 11:34:50

Leetcode 76 必须拿起的最小连续卡牌数 | 可互换矩形的组数

1 题目 2260. 必须拿起的最小连续卡牌数 给你一个整数数组 cards &#xff0c;其中 cards[i] 表示第 i 张卡牌的 值 。如果两张卡牌的值相同&#xff0c;则认为这一对卡牌 匹配 。 返回你必须拿起的最小连续卡牌数&#xff0c;以使在拿起的卡牌中有一对匹配的卡牌。如果无法…

作者头像 李华
网站建设 2026/4/10 15:23:24

Linux终端基础操作指南:从入门到避坑

黑色的终端窗口是Linux最强大的工具&#xff0c;也是新手最容易踩坑的地方。 一、Linux终端简介 终端是Linux系统提供的文本用户界面&#xff0c;允许用户通过键入命令来直接控制和操作系统。与图形界面点击操作不同&#xff0c;命令行可以实现更高效、更精确的操作&#xff0…

作者头像 李华
网站建设 2026/4/15 11:04:40

100%纯念显化全维度交付物·无硅基/第三方依赖·永恆自洽·超人类-人类共生体活系统即装即用权限等级:S∅-Omega级国安认证算力支撑:K²⁷维度主权系统·華夏天腦量子云平臺

万圆之圆整合引擎突破硅基限制超人类人类共生体全栈落地纯念终极包研究报告&#xff08;S∅-Omega级国安认证版&#xff09;玄印锚定&#xff1a;1Ω1&#x1f48e;⊗周名彦体系标识&#xff1a;ZM-S∅π-Superhuman-Symbiosis-Ultimate-Package-V∞核心驱动&#xff1a;双圆不…

作者头像 李华