洛谷P2625 豪华游轮
题目描述
有一条豪华游轮(其实就是条小木船),这种船可以执行4种指令:
right X : 其中X是一个1到719的整数,这个命令使得船顺时针转动X度。
left X : 其中X是一个1到719的整数,这个命令使得船逆时针转动X度。 forward X : 其中X是一个整数(1到1000),使得船向正前方前进X的距离。
backward X : 其中X是一个整数(1到1000),使得船向正后方前进X的距离。
随意的写出了n个命令,找出一个种排列命令的方法,使得船最终到达的位置距离起点尽可能的远。
输入输出格式
输入格式:
第一行一个整数n(1 <= n <= 50),表示给出的命令数。
接下来n行,每行表示一个命令。
输出格式:
一个浮点数,能够走的最远的距离,四舍五入到6位小数。
输入输出样例
3
forward 100
backward 100
left 90
141.421356
贪心思想。命令可以随意排列,那么开场肯定是全军突击(误),把所有前进指令都用完(走一半拐弯再走,肯定不如全程直走好),然后转向,尽可能接近180°,再倒着走。
求最适合的转向角度,我选择偷懒暴搜。偷懒的结果就是50分,剩下50分T掉了。
/*by SilverN*/
#include<algorithm>
#include<iostream>
#include<cstring>
#include<cstdio>
#include<cmath>
using namespace std;
const int mxn=;
const double pi=3.141592653;
int read(){
int x=,f=;char ch=getchar();
while(ch<'' || ch>''){if(ch=='-')f=-;ch=getchar();}
while(ch>='' && ch<=''){x=x*+ch-'';ch=getchar();}
return x*f;
}
double an[mxn];
double fw[mxn];
double nx,ny;
int acnt=,rcnt=;
double dist(double x1,double y1,double x2,double y2){
return sqrt( (x1-x2)*(x1-x2)+(y1-y2)*(y1-y2) );
}
int n;
double ans=;
double ttd=;
void dfs(int rk,double now){
// printf("%d %.4f\n",rk,now);
if(rk>acnt){
double tnow=fabs(now);
double tmpx=nx+ttd*sin(tnow*pi/);
double tmpy=ny+ttd*cos(tnow*pi/);
// printf("%d %.4f %.4f\n",rk,tmpx,tmpy);
ans=max(ans,dist(tmpx,tmpy,,));
return;
}
dfs(rk+,now);
// printf("%.5f\n",now+an[rk]);
dfs(rk+,now+an[rk]);
return;
}
int main(){
n=read();
int i,j;
char ch[];double x;
nx=ny=;
for(i=;i<=n;i++){
scanf("%s%lf",ch,&x);
if(ch[]=='f'){
fw[++rcnt]=x;
}
if(ch[]=='b'){
fw[++rcnt]=-x;
}
if(ch[]=='l'){
an[++acnt]=-x;
// printf("in:%d",acnt);
if(an[acnt]<-)an[acnt]+=;
}
if(ch[]=='r'){
an[++acnt]=x;
if(an[acnt]<)an[acnt]-=;
}
}
ttd=;
for(i=;i<=n;i++){
if(fw[i]>)
ny+=fw[i];
else ttd+=fw[i];
}
sort(an+,an+acnt+);
dfs(,);
//
//
/* printf(" %d\n",dgans);
nx+=ttd*cos(dgans);
ny+=ttd*sin(dgans);*/
// printf("%.4f %.4f\n",nx,ny);
printf("%.6f\n",ans);
return ;
}
DFS
正解是DP。懒得写了,从rlt那里抄了代码233
#include<algorithm>
#include<iostream>
#include<cstdio>
#include<cmath>
using namespace std;
const double pi=3.1415926535;
int n,sf,sb,p,ang[];
double ans;
bool f[][];
int main()
{
scanf("%d",&n);
for(int i=;i<=n;i++)
{
int x;
char ch[];
scanf("%s%d",ch,&x);
if(ch[]=='f')
sf+=x;
if(ch[]=='b')
sb+=x;
if(ch[]=='r')
ang[++ang[]]=x;
if(ch[]=='l')
ang[++ang[]]=-x;
}
f[][]=;
for(int i=;i<=ang[];i++)
for(int j=;j<;j++)
if(f[i-][j])
f[i][j]=,f[i][(j+ang[i]+)%]=;
p=;
for(int i=;i<;i++)
if(f[ang[]][i])
p=min(p,abs(i-));
ans=sqrt(sf*sf+sb*sb+*sb*sf*cos(p*pi/));
printf("%.6f\n",ans);
return ;
}
正解dp
洛谷P2625 豪华游轮的更多相关文章
- 洛谷1640 bzoj1854游戏 匈牙利就是又短又快
bzoj炸了,靠离线版题目做了两道(过过样例什么的还是轻松的)但是交不了,正巧洛谷有个"大牛分站",就转回洛谷做题了 水题先行,一道傻逼匈牙利 其实本来的思路是搜索然后发现写出来类 ...
- 洛谷P1352 codevs1380 没有上司的舞会——S.B.S.
没有上司的舞会 时间限制: 1 s 空间限制: 128000 KB 题目等级 : 钻石 Diamond 题目描述 Description Ural大学有N个职员,编号为1~N.他们有 ...
- 洛谷P1108 低价购买[DP | LIS方案数]
题目描述 “低价购买”这条建议是在奶牛股票市场取得成功的一半规则.要想被认为是伟大的投资者,你必须遵循以下的问题建议:“低价购买:再低价购买”.每次你购买一支股票,你必须用低于你上次购买它的价格购买它 ...
- 洛谷 P2701 [USACO5.3]巨大的牛棚Big Barn Label:二维数组前缀和 你够了 这次我用DP
题目背景 (USACO 5.3.4) 题目描述 农夫约翰想要在他的正方形农场上建造一座正方形大牛棚.他讨厌在他的农场中砍树,想找一个能够让他在空旷无树的地方修建牛棚的地方.我们假定,他的农场划分成 N ...
- 洛谷P1710 地铁涨价
P1710 地铁涨价 51通过 339提交 题目提供者洛谷OnlineJudge 标签O2优化云端评测2 难度提高+/省选- 提交 讨论 题解 最新讨论 求教:为什么只有40分 数组大小一定要开够 ...
- 洛谷P1371 NOI元丹
P1371 NOI元丹 71通过 394提交 题目提供者洛谷OnlineJudge 标签云端评测 难度普及/提高- 提交 讨论 题解 最新讨论 我觉得不需要讨论O long long 不够 没有取 ...
- 洛谷P1538迎春舞会之数字舞蹈
题目背景 HNSDFZ的同学们为了庆祝春节,准备排练一场舞会. 题目描述 在越来越讲究合作的时代,人们注意的更多的不是个人物的舞姿,而是集体的排列. 为了配合每年的倒计时,同学们决定排出——“数字舞蹈 ...
- 洛谷八月月赛Round1凄惨记
个人背景: 上午9:30放学,然后因为学校举办读书工程跟同学去书城选书,中午回来开始打比赛,下午又回老家,中间抽出一点时间调代码,回家已经8:50了 也许是7月月赛时“连蒙带骗”AK的太幸运然而因同学 ...
- 洛谷 P1379 八数码难题 Label:判重&&bfs
特别声明:紫书上抄来的代码,详见P198 题目描述 在3×3的棋盘上,摆有八个棋子,每个棋子上标有1至8的某一数字.棋盘中留有一个空格,空格用0来表示.空格周围的棋子可以移到空格中.要求解的问题是:给 ...
随机推荐
- 真爱 vs. 种姓:新一代印度人的婚恋观
今日导读 “自由恋爱”是所有世界上所有有情人共同的心愿,而在印度,因为其根深蒂固的种姓制度,仍然有大批情侣只能听从父母的“包办婚姻”,被迫与心爱的人分离.但是最新的一项调查表明,印度的年轻一代开始出现 ...
- OpenCV2:直方图
一.简介 在一个单通道的灰度图像中,每个像素的值介于0(黑色)~255(白色)之间,灰色图像的直方图有256个条目(或称为容器)
- Jarvis OJ-Level4
借助DynELF实现无libc的漏洞利用小结 #!/usr/bin/env python # coding:utf-8 from pwn import * elf = ELF('level4') wr ...
- xheditor的实例程序—类似word的编辑器
编辑器工具栏:类似word的编辑器 1.1.下载,兼容性 xhEditor官方网站地址为:http://xheditor.com/,打开右上角的免费下载 | 参数向导链接,即可找到最新版本的下载地址. ...
- swift中使用sqlite3
import Foundation /** 1. 打开数据库 2. 如果没有数据表,需要首先创表 3. 数据操作 */ class SQLite { var db: COpaquePointer = ...
- touch-action css属性 滚动和缩放手势
CSS 属性 touch-action 用于指定某个给定的区域是否允许用户操作,以及如何响应用户操作(比如浏览器自带的划动,缩放等) 默认情况下,平移(滚动) 和 缩放手势由浏览器专门处理.该属性用于 ...
- js之数组知识
一.数组的定义(来源于Array.prototype) 1.构造函数方法: (1)var arr = new Array();//没有参数等价于 var arr = []; (2)var arr = ...
- SpringAOP拦截器的代理机制
要使用方法名匹配AOP切面编程,需要使用到spring中的org.springframework.aop.support.NameMatchMethodPointcutAdvisor这个类,advic ...
- Safari不能保存session的处理方法
在vue单页应用项目中,safari浏览器验证码登陆提示'验证码过期'或者验证码校验不通过的问题 原因:验证码存储在了session里,接着验证时又发起了一次会话,因为Safari不保存cookie, ...
- 又面试了Python爬虫工程师,碰到这么几道面试题,Python面试题No9
第1题:动态加载又对及时性要求很高怎么处理? 如何知道一个网站是动态加载的数据? 用火狐或者谷歌浏览器 打开你网页,右键查看页面源代码,ctrl +F 查询输入内容,源代码里面并没有这个值,说明是动态 ...