洛谷 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)个相异的点,在其中任何一个点上放一个很小的油滴,那么这个油滴会一直扩展,直到接触到其他油滴或者框子的边界.必须等一个油滴扩展完毕才能放置下一个油滴. ...
随机推荐
- HTML DOM 之<textare>标签
对于DOM元素节点textarea的value值,下面举例说一下. 1. <textarea><textarea> 2.<textarea> <textare ...
- JavaScript的模块化之AMD&CMD规范
前端开发常常会遇到的问题: 1.恼人的命名冲突: 2.繁琐的文件依赖: 模块化开发的优势: 1.解决命名冲突和依赖管理: 2.模块的版本管理: 3.提高代码的可维护性: 4.前端性能优化: JavaS ...
- java关键包简易说明
java.lang 语言核心类,系统自动导入. java.util java工具类.集合框架.时间,日历等. java.net 网络编程接口和类. java.io 流的接口和类 java.te ...
- 整理:Javascript获取数组中的最大值和最小值的方法汇总
方法一: ? 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 //最小值 Array.prototype.min = function ...
- React state的使用
相对于angular.js的双向数据绑定,React 可以使用State来实现. React 里,只需更新组件的 state,然后根据新的 state 重新渲染用户界面(不要操作 DOM). this ...
- windows server 2008 wamp安装报000F15A0解决方法
wampserver2.2c-x64 原因:缺少Visual C++ 2008 Runtime x64,官网地址http://www.microsoft.com/zh-cn/download/deta ...
- Mahout推荐算法API详解
转载自:http://blog.fens.me/mahout-recommendation-api/ Hadoop家族系列文章,主要介绍Hadoop家族产品,常用的项目包括Hadoop, Hive, ...
- iOS 企业证书的使用文档
IN-HOUSE应用程序分发 下面介绍下使用网络方式进行部署的方式,用户直接在iPhone/iPad的Safari浏览器里面输入URL地址即可安装, 注意:目前对于这种企业级开发的应用程序最好的分发方 ...
- js的类型及调试下的辨识
<script> var s1 = '11'; var s2 = 11; var s3 = true; console.log("我的类型是"+typeof(s1)+& ...
- 阿里云CentOS7系列二 -- 安装Tomcat7的方法
前面讲到了JDK在CentOS7 环境下的安装步骤.这次来分享安装Tomcat7的安装步骤: Tomcat7 安装包: 链接: http://pan.baidu.com/s/1geKwASN 密码: ...
