试题 算法训练 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的更多相关文章

  1. Java实现 蓝桥杯 算法训练 猴子吃包子(暴力)

    试题 算法训练 猴子吃包子 问题描述 从前,有一只吃包子很厉害的猴子,它可以吃无数个包子,但是,它吃不同的包子速度也不同:肉包每秒钟吃x个:韭菜包每秒钟吃y个:没有馅的包子每秒钟吃z个:现在有x1个肉 ...

  2. Java实现蓝桥杯 算法训练 大等于n的最小完全平方数

    试题 算法训练 大等于n的最小完全平方数 资源限制 时间限制:1.0s 内存限制:256.0MB 问题描述 输出大等于n的最小的完全平方数. 若一个数能表示成某个自然数的平方的形式,则称这个数为完全平 ...

  3. java实现 蓝桥杯 算法训练 Password Suspects

    问题描述 在年轻的时候,我们故事中的英雄--国王 Copa--他的私人数据并不是完全安全地隐蔽.对他来说是,这不可接受的.因此,他发明了一种密码,好记又难以破解.后来,他才知道这种密码是一个长度为奇数 ...

  4. Java实现 蓝桥杯 算法训练VIP 报数(暴力+数学)约瑟夫环问题

    试题 算法训练 报数 问题描述 现有n个同学站成一圈,顺时针编号1至n.从1号同学开始顺时针1/2报数,报到1的同学留在原地,报到2的同学退出圆圈,直到只剩一名同学为止.问最后剩下的同学编号. 输入格 ...

  5. Java实现蓝桥杯 算法训练 ALGO-15 旅行家的预算

    问题描述 一个旅行家想驾驶汽车以最少的费用从一个城市到另一个城市(假设出发时油箱是空的).给定两个城市之间的距离D1.汽车油箱的容量C(以升为单位).每升汽油能行驶的距离D2.出发点每升汽油价格P和沿 ...

  6. Java实现 蓝桥杯 算法训练 审美课

    算法训练 审美课 时间限制:1.0s 内存限制:256.0MB 提交此题 问题描述 <审美的历程>课上有n位学生,帅老师展示了m幅画,其中有些是梵高的作品,另外的都出自五岁小朋友之手.老师 ...

  7. Java实现 蓝桥杯 算法训练 多阶乘计算

    试题 算法训练 多阶乘计算 问题描述 我们知道,阶乘n!表示n*(n-1)(n-2)-21, 类似的,可以定义多阶乘计算,例如:5!!=531,依次可以有n!..!(k个'!',可以简单表示为n(k) ...

  8. Java实现 蓝桥杯 算法训练 找零钱

    试题 算法训练 找零钱 问题描述 有n个人正在饭堂排队买海北鸡饭.每份海北鸡饭要25元.奇怪的是,每个人手里只有一张钞票(每张钞票的面值为25.50.100元),而且饭堂阿姨一开始没有任何零钱.请问饭 ...

  9. Java实现 蓝桥杯 算法训练 第五次作业:字符串排序

    试题 算法训练 第五次作业:字符串排序 问题描述 输入一个小写字符串,按从小到大的顺序输出. 输入格式 bcaed 输出格式 abcde 顶格输出,中间没有空格 样例输入 一个满足题目要求的输入范例. ...

随机推荐

  1. Algorithms - Priority Queue - 优先队列

    Priority queue - 优先队列 相关概念 Priority queue优先队列是一种用来维护由一组元素构成的集合S的数据结构, 其中的每一种元素都有一个相关的值,称为关键字(key). 一 ...

  2. 自己动手在Linux系统实现一个everything程序

    大家好,我是良许. 我们知道,在 Windows 下,有一款非常实用的神器,叫作 Everything ,它可以在极短的时间里,搜索出来你所想要的文件/目录,如下图示: Linux 下也有一些类似于 ...

  3. 多线程测试时的辅助类--CountDownLatch

    多线程时,很多时候由于mian线程与多线程结束时间不可控,造成无法测试 辅助测试类---CountDownLatch 我看的视频教程匿名内部类无法使用外部的变量,所以CountDownLatch定义为 ...

  4. [hdu4631 Sad Love Story]最近点对,枚举

    题意:S是平面内点的集合,初始为空,每次向集合里面加入一个点P(x,y),询问S内最近点对的距离的平方和 思路:设当前集合的答案为D,则找到集合里面横坐标在(x-√D,x+√D)内的数,用它们来更新答 ...

  5. [hdu5199]统计数据的水题

    题意:统计一个数出现了多少次,统计后删去它所有的出现.思路:乱搞..自己没事写的hash,不过赶脚效率有点低. #pragma comment(linker, "/STACK:1024000 ...

  6. sql 取值时将字符串类型数字转化成整形

    select cast(a.Vchcode as int) as avchcode,a.ptypeid,a.assqty,unit,b.pfullname,b.standard,b.type from ...

  7. shiro 实现自定义权限规则校验

    <span style="font-family: Arial, Helvetica, sans-serif;">在系统中使用shiro进行权限管理,当用户访问没有权限 ...

  8. Python中range, np.arange, np.linspace的区别

    目录 range np.arange np.linspace range 特点 range()是python内置函数,指定开始值,终值和步长生成等差数列的一维数组 不包含终值 步长只能是整数,生成整数 ...

  9. 修改jupyter默认保存文件的目录

    1.打开 Anaconda Prompt输入命令 jupyter notebook --generate-config 2.可以看到生成了目录及jupyter notebook的配置文件,打开该文件. ...

  10. XCode Interface Builder开发——1

    XCode Interface Builder开发--1 创建Xcode项目 选择第二个选项 选择Single View App,点击Next 设置完后点击Next Xcode基本面板 导航面板 工具 ...