Java实现 蓝桥杯 算法训练 Balloons in a Box
试题 算法训练 Balloons in a Box
问题描述
你要写一个程序,使得能够模拟在长方体的盒子里放置球形的气球。
接下来是模拟的方案。假设你已知一个长方体的盒子和一个点集。每一个点代表一个可以放置气球的位置。在一个点上放置一个气球,就是以这个点为球心,然后让这个球膨胀,直到触及盒子的边缘或者一个之前已经被放置好的气球。你不能使用一个在盒子外面或者在一个之前已经放置好的气球里面的点。但是,你可以按你喜欢的任意顺序使用这些点,而且你不需要每个点都用。你的目标是按照某种顺序在盒子里放置气球,使得气球占据的总体积最大。
你要做的是计算盒子里没被气球占据的体积。
输入格式
第一行包含一个整数n表示集合里点的个数(1≤n≤6)。第二行包含三个整数表示盒子的一个角落的(x,y,z)坐标,第三行包含与之相对的那个角落的(x,y,z)坐标。接下来n行,每行包含三个整数,表示集合中每个点的(x,y,z)坐标。这个盒子的每维的长度都是非零的,而且它的边与坐标轴平行。
输出格式
只有一行,为那个盒子没被气球占据的最小体积(四舍五入到整数)。
样例输入
2
0 0 0
10 10 10
3 3 3
7 7 7
样例输出
774
数据规模和约定
所有坐标的绝对值小于等于1000
对于20%的数据:n=1
对于50%的数据:1≤n≤3
对于100%的数据:1≤n≤6
import java.util.Scanner;
public class Main {
static int n;
static int[] visit;
static point d;
static point u;
static point[] t;
static double max;
static int[] now;
public static void main(String[] args) {
Scanner in = new Scanner(System.in);
n = in.nextInt();
visit=new int[n+1];
now=new int[n+1];
d=new point(in.nextInt(),in.nextInt(),in.nextInt());
u=new point(in.nextInt(),in.nextInt(),in.nextInt());
point mins = new point(Math.min(d.x, u.x), Math.min(d.y, u.y), Math.min(d.z, u.z));
point maxs = new point(Math.max(d.x, u.x), Math.max(d.y, u.y), Math.max(d.z, u.z));
t = new point[n+1];
for(int i =1;i<=n;){
int x = in.nextInt();
int y = in.nextInt();
int z = in.nextInt();
if(x<mins.x||x>maxs.x||y<mins.y||y>maxs.y||z<mins.z||z>maxs.z){
n--;
continue;
}
t[i++] = new point(x,y,z);
}
in.close();
dfs(1);
double v = Math.abs((d.x-u.x)*(d.y-u.y)*(d.z-u.z));
System.out.println(String.format("%.0f",v-max));
}
static void dfs(int i){
for(int j = 1;j<=n;j++){
if(visit[j]==0){
now[i]=j;
visit[j] = 1;
if(i==n){
fun();
}
else {
dfs(i+1);
}
visit[j] = 0;
}
}
}
static void fun() {
double all=0.0;
int no;
double r1;
double r2;
double r3;
double r4;
for(int i =1;i<=n;i++){
t[i].r=0.0;
}
for(int i=1;i<=n;i++){
no = now[i];
r1=Math.min(Math.abs(t[no].x-d.x),Math.abs(t[no].x-u.x));
r2=Math.min(Math.abs(t[no].y-d.y),Math.abs(t[no].y-u.y));
r3=Math.min(Math.abs(t[no].z-d.z),Math.abs(t[no].z-u.z));
t[no].r=Math.min(r1, Math.min(r2, r3));
for(int j = 1;j<=n;j++){
if(j==no||t[j].r==0){
continue;
}
r4=Math.sqrt((t[no].x-t[j].x)*(t[no].x-t[j].x)
+(t[no].y-t[j].y)*(t[no].y-t[j].y)
+(t[no].z-t[j].z)*(t[no].z-t[j].z))-t[j].r;
t[no].r=Math.min(t[no].r, r4);
if(t[no].r<0.0){
t[no].r=0.0;
}
}
all += 4.0/3*Math.PI*Math.pow(t[no].r, 3);
}
if(max<all){
max = all;
}
}
}
class point{
int x;
int y;
int z;
double r;
public point(int a,int b,int c){
x=a;
y=b;
z=c;
}
}
Java实现 蓝桥杯 算法训练 Balloons in a Box的更多相关文章
- Java实现 蓝桥杯 算法训练 猴子吃包子(暴力)
试题 算法训练 猴子吃包子 问题描述 从前,有一只吃包子很厉害的猴子,它可以吃无数个包子,但是,它吃不同的包子速度也不同:肉包每秒钟吃x个:韭菜包每秒钟吃y个:没有馅的包子每秒钟吃z个:现在有x1个肉 ...
- Java实现蓝桥杯 算法训练 大等于n的最小完全平方数
试题 算法训练 大等于n的最小完全平方数 资源限制 时间限制:1.0s 内存限制:256.0MB 问题描述 输出大等于n的最小的完全平方数. 若一个数能表示成某个自然数的平方的形式,则称这个数为完全平 ...
- java实现 蓝桥杯 算法训练 Password Suspects
问题描述 在年轻的时候,我们故事中的英雄--国王 Copa--他的私人数据并不是完全安全地隐蔽.对他来说是,这不可接受的.因此,他发明了一种密码,好记又难以破解.后来,他才知道这种密码是一个长度为奇数 ...
- Java实现 蓝桥杯 算法训练VIP 报数(暴力+数学)约瑟夫环问题
试题 算法训练 报数 问题描述 现有n个同学站成一圈,顺时针编号1至n.从1号同学开始顺时针1/2报数,报到1的同学留在原地,报到2的同学退出圆圈,直到只剩一名同学为止.问最后剩下的同学编号. 输入格 ...
- Java实现蓝桥杯 算法训练 ALGO-15 旅行家的预算
问题描述 一个旅行家想驾驶汽车以最少的费用从一个城市到另一个城市(假设出发时油箱是空的).给定两个城市之间的距离D1.汽车油箱的容量C(以升为单位).每升汽油能行驶的距离D2.出发点每升汽油价格P和沿 ...
- Java实现 蓝桥杯 算法训练 审美课
算法训练 审美课 时间限制:1.0s 内存限制:256.0MB 提交此题 问题描述 <审美的历程>课上有n位学生,帅老师展示了m幅画,其中有些是梵高的作品,另外的都出自五岁小朋友之手.老师 ...
- Java实现 蓝桥杯 算法训练 多阶乘计算
试题 算法训练 多阶乘计算 问题描述 我们知道,阶乘n!表示n*(n-1)(n-2)-21, 类似的,可以定义多阶乘计算,例如:5!!=531,依次可以有n!..!(k个'!',可以简单表示为n(k) ...
- Java实现 蓝桥杯 算法训练 找零钱
试题 算法训练 找零钱 问题描述 有n个人正在饭堂排队买海北鸡饭.每份海北鸡饭要25元.奇怪的是,每个人手里只有一张钞票(每张钞票的面值为25.50.100元),而且饭堂阿姨一开始没有任何零钱.请问饭 ...
- Java实现 蓝桥杯 算法训练 第五次作业:字符串排序
试题 算法训练 第五次作业:字符串排序 问题描述 输入一个小写字符串,按从小到大的顺序输出. 输入格式 bcaed 输出格式 abcde 顶格输出,中间没有空格 样例输入 一个满足题目要求的输入范例. ...
随机推荐
- 记一次 spinor flash 读速度优化
背景 某个项目使用的介质是 spinor, 其 bootloader 需要从 flash 中加载 os. 启动速度是一个关键指标,需要深入优化.其他部分的优化暂且略过,此篇主要记录对 nor 读速度的 ...
- 【Spark】一张图看懂Spark的运行架构,以standAlone模式为例
- 【matlab 基础篇 02】基础知识一键扫盲,看完即可无障碍编程(超详细+图文并茂)
博主快速入门matlab,系统地整理一遍,如何你和我一样是一个新手,那么此文很适合你: 本人能力有限,文中难免有错误和纰漏之处,请大佬们不吝赐教 创作不易,如果本文帮到了您: 请帮忙点个赞
- C# 数据操作系列 - 3. ADO.NET 离线查询
0. 前言 在上一篇中,我故意留下了查询的示范没讲.虽然说可以通过以下代码获取一个DataReader: IDataReader reader = command.ExecuteReader(); 然 ...
- 初探numpy
安装numpy 通过python pip安装numpy pip install numpy numpy ndarray对象 创建ndarray对象只需调用numpy的array函数即可 numpy.a ...
- 比AtomicLong更优秀的LongAdder确定不来了解一下吗?
前言 思维导图.png 文章中所有高清无码图片在公众号号回复: 图片666 即可查阅, 可直接关注公众号:壹枝花算不算浪漫 最近阿里巴巴发布了Java开发手册(泰山版) (公众号回复: 开发手册 可收 ...
- Redux:store
Store是一个对象.他有如下职责: 1.存放state 2.对外提供访问state的接口: getState() 3.允许state更新:dispatch(action) 4.注册监听器: subs ...
- Maven 私服你应该不陌生吧,可你会用 Artifactory 搭建吗?
JFrog Artifactory 是一个 Artifacts 仓库管理平台,它支持所有的主流打包格式.构建工具和持续集成(CI)服务器.它将所有二进制内容保存在一个单一位置并提供一个接口,这使得用户 ...
- redis起步 zz
Rdis和JQuery一样是纯粹为应用而产生的,这里记录的是在CentOS 5.7上学习入门文章: 1.Redis简介 Redis是一个key-value存储系统.和Memcached类似,但是解决了 ...
- rasdaman介绍及安装
一.分布式介绍 Rasdaman中的主节点称为Rasdaman的主机,它充当中央Rasdaman请求分派器并且控制所有服务器进程.Rasdaman管理器接收客户机请求并将这些请求分配给服务器进程.服务 ...