洛谷 P1378 油滴扩展 Label:搜索
题目描述
在一个长方形框子里,最多有N(0≤N≤6)个相异的点,在其中任何一个点上放一个很小的油滴,那么这个油滴会一直扩展,直到接触到其他油滴或者框子的边界。必须等一个油滴扩展完毕才能放置下一个油滴。那么应该按照怎样的顺序在这N个点上放置油滴,才能使放置完毕后所有油滴占据的总体积最大呢?(不同的油滴不会相互融合)
注:圆的面积公式V=pi*r*r,其中r为圆的半径。
输入输出格式
输入格式:
第1行一个整数N。
第2行为长方形边框一个顶点及其对角顶点的坐标,x,y,x’,y’。
接下去N行,每行两个整数xi,yi,表示盒子的N个点的坐标。
以上所有的数据都在[-1000,1000]内。
输出格式:
一行,一个整数,长方形盒子剩余的最小空间(结果四舍五入输出)
输入输出样例
2
20 0 10 10
13 3
17 7
50
代码
12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394#include<iostream>#include<cstring>#include<algorithm>#include<cstdio>#include<vector>#include<cstdlib>#include<cmath>#define ll long long#define eps 1e-8#define INF 0x3f3f3f3f#define pi 3.141592653589usingnamespacestd;structcc{doublex,y;}nod[10];doubled_nod[10][10],d_wall[10];doubler[10];intN,S,vis[10];doubleans;doublecal_d(inti,intj){doublex1=nod[i].x,y1=nod[i].y,x2=nod[j].x,y2=nod[j].y;returnsqrt((x1-x2)*(x1-x2)+(y1-y2)*(y1-y2));}doublecal_s(doubler){returnpi*r*r;}voidinit_(){doublex1,x2,y1,y2;scanf("%d",&N);scanf("%lf%lf%lf%lf",&x1,&y1,&x2,&y2);S=abs(x1-x2)*abs(y1-y2);for(inti=1;i<=N;i++){scanf("%lf%lf",&nod[i].x,&nod[i].y);}for(inti=1;i<=N;i++){for(intj=i+1;j<=N;j++){d_nod[i][j]=d_nod[j][i]=cal_d(i,j);}}memset(d_wall,0x3f,sizeof(d_wall));for(inti=1;i<=N;i++){doublex=nod[i].x,y=nod[i].y;d_wall[i]=min(abs(x-x1),abs(x-x2));doubletmp=min(abs(y-y1),abs(y-y2));d_wall[i]=min(tmp,d_wall[i]);}}voiddfs(intx,intdep){doublenowr=d_wall[x];for(inti=1;i<=N;i++){if(i==x)continue;if(vis[i]) nowr=min(nowr,d_nod[x][i]-r[i]);}if(nowr<0) nowr=0;r[x]=nowr;if(dep==N){doublesum=0.0;for(inti=1;i<=N;i++) sum+=cal_s(r[i]);ans=max(ans,sum);// for(int i=1;i<=N;i++) cout<<r[i]<<endl;// puts("-------------");return;}vis[x]=1;for(inti=1;i<=N;i++){if(!vis[i]) dfs(i,dep+1);}r[x]=0;vis[x]=0;}voidwork(){for(inti=1;i<=N;i++) dfs(i,1);cout<<(int(S-ans+0.5))<<endl;}intmain(){// freopen("01.in","r",stdin);init_();work();return0;}这是我写过的最最最朴素的搜索,没有之一
Line 59 这样写只有60分 nowr=min(nowr,d_nod[x][i]-r[i]);
然后圆周率总得背几位出来吧
给你萌安利一个背数字的好方法,想背啥把啥当作手机密码或者某个账的密码
听3.14159265358979323846
不仅可以锻炼记忆力,还可以让你戒掉手机hhh
洛谷 P1378 油滴扩展 Label:搜索的更多相关文章
- 洛谷P1378 油滴扩展(搜索)
洛谷P1378 油滴扩展 直接暴力搜索更新答案就可以了. 时间复杂度为 \(O(n!)\) . #include<stdio.h> #include<stdlib.h> #in ...
- 洛谷P1378 油滴扩展
P1378 油滴扩展 题目描述 在一个长方形框子里,最多有N(0≤N≤6)个相异的点,在其中任何一个点上放一个很小的油滴,那么这个油滴会一直扩展,直到接触到其他油滴或者框子的边界.必须等一个油滴扩展完 ...
- 洛谷 P1378 油滴扩展 改错
P1378 油滴扩展 题目描述 在一个长方形框子里,最多有\(N(0≤N≤6)\)个相异的点,在其中任何一个点上放一个很小的油滴,那么这个油滴会一直扩展,直到接触到其他油滴或者框子的边界.必须等一个油 ...
- 洛谷 P1378 油滴扩展
P1378 油滴扩展 题目描述 在一个长方形框子里,最多有N(0≤N≤6)个相异的点,在其中任何一个点上放一个很小的油滴,那么这个油滴会一直扩展,直到接触到其他油滴或者框子的边界.必须等一个油滴扩展完 ...
- 洛谷P1378油滴扩展
题目描述 在一个长方形框子里,最多有N(0≤N≤6)个相异的点,在其中任何一个点上放一个很小的油滴,那么这个油滴会一直扩展,直到接触到其他油滴或者框子的边界. 必须等一个油滴扩展完毕才能放置下一个油滴 ...
- 洛谷1378 油滴扩展 dfs进行回溯搜索
题目链接:https://www.luogu.com.cn/problem/P1378 题目中给出矩形的长宽和一些点,可以在每个点放油滴,油滴会扩展,直到触碰到矩形的周边或者其他油滴的边缘,求出剩余面 ...
- P1378 油滴扩展——搜索小记
P1378 油滴扩展 记得这道题好久以前(好像是上个学期?) 就想做了,但是看着里面的半径边界好像很难处理就没做(主要是当时刚学OI(菜还给自己找借口)): 今天上午一直研究SG函数,做的都自闭了,晚 ...
- [动态规划]P1378 油滴扩展
题目描述 在一个长方形框子里,最多有N(0≤N≤6)个相异的点,在其中任何一个点上放一个很小的油滴,那么这个油滴会一直扩展,直到接触到其他油滴或者框子的边界.必须等一个油滴扩展完毕才能放置下一个油滴. ...
- P1378 油滴扩展
题目描述 在一个长方形框子里,最多有N(0≤N≤6)个相异的点,在其中任何一个点上放一个很小的油滴,那么这个油滴会一直扩展,直到接触到其他油滴或者框子的边界.必须等一个油滴扩展完毕才能放置下一个油滴. ...
随机推荐
- 如何让两个div在同一行显示?一个float搞定
最近在学习div和css,遇到了一些问题也解决了很多以前以为很难搞定的问题.比如:如何让两个div显示在同一行呢?(不是用table表格,table对SE不太友好)其实,<div> 是一个 ...
- 第二篇 基于.net搭建热插拔式web框架(沙箱的构建)
上周五写了一个实现原理篇,在评论中看到有朋友也遇到了我的问题,真的是有种他乡遇知己的感觉,整个系列我一定会坚持写完,并在最后把代码开源到git中.上一篇文章很多人看了以后,都表示不解,觉得不知道我到底 ...
- web加密的基本概念
1.需求 了解web加密的一些基础概念. 2.基本概念 a.对称加密方式 对称加密方式 加密和解密用同一个密钥 不足之处是,交易双方都使用同样钥匙,安全性得不到保证.此外,每对用户每次使用对称加密算法 ...
- 购物车相关 js
<div class="caigou"> <form action="" method="post"> <di ...
- Linux下用户组、文件权限详解
在linux中的每个用户必须属于一个组,不能独立于组外.在linux中每个文件有所有者.所在组.其它组的概念 - 所有者 - 所在组 - 其它组 - 改变用户所在的组 所有者 一般为文件的创建者,谁创 ...
- 对偶SVM
1.对偶问题的推导 为什么要求解对偶问题?一是对偶问题往往更容易求解,二是可以自然的引入核函数. 1.1 用拉格朗日函数将原问题转化为"无约束"等价问题 原问题是: 写出它的拉格朗 ...
- 《PHP数组函数》笔记
① in_array() 检查数组中是否存在某个值;有两个参数,第一个参数是要查找的值,第二个参数是数组名,返回值为布尔,找到则ture否则false; ② array_search 在数组中搜索给定 ...
- nova instance出错:"message": "Proxy error: 502 Read from server failed
执行 $ nova resize instance1 时候出错: {, "details": " File \"/opt/stack/nova/nova/com ...
- 触发bfd 的条件
满足下列条件之一就可触发BFC [1]根元素,即HTML元素 [2]float的值不为none [3]overflow的值不为visible [4]display的值为inline-block.tab ...
- mysql 学习官网
http://www.runoob.com/mysql/mysql-install.html
