可耻的低级错误。。。。

 这几天在AABB碰撞时总是不准确
原理上推了好几遍,没有任何问题啊
于是一句代码一句代码打印调试
最后,在最底层的一块,发现问题了

aabb.clear();
clear()用于通过addPoint来构造一个全新的aabb之前,把所有顶点信息清空掉
也就是设置为Float.MAX_VALUE和Float.MIN_VALUE
我之前aabb.clear的代码如下

public void Clear() {
        minLocal.set(Float.MAX_VALUE, Float.MAX_VALUE,
                Float.MAX_VALUE);
        maxLocal.set(Float.MIN_VALUE, Float.MIN_VALUE,
                Float.MIN_VALUE);
        minWorld.set(Float.MAX_VALUE, Float.MAX_VALUE,
                Float.MAX_VALUE);
        maxWorld.set(Float.MIN_VALUE, Float.MIN_VALUE,
                Float.MIN_VALUE);
    }

貌似很对啊,Float.MIN_VALUE,最小值啊。。。。
可问题就是出在这里
在Float的定义里
public static final float MIN_VALUE = 1.4E-45f;
虽然看上去的确非常非常小了
但别忘了,丫是正号的, 55555555555
所以Float所能代表的最小值,不是Float.MIN_VALUE
而是
-Float.MAX_VALUE !!!!!

就这个问题,搞了我大半天。。。。
所以正确的方式如下
public void Clear() {
        minLocal.set(Float.MAX_VALUE, Float.MAX_VALUE,
                Float.MAX_VALUE);
        maxLocal.set(-Float.MAX_VALUE, -Float.MAX_VALUE,
                -Float.MAX_VALUE);
        minWorld.set(Float.MAX_VALUE, Float.MAX_VALUE,
                Float.MAX_VALUE);
        maxWorld.set(-Float.MAX_VALUE, -Float.MAX_VALUE,
                -Float.MAX_VALUE);
    }
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
题目描述 小贝现在上六年级,正是长身体的时候,小贝的妈妈给小贝规定了每天要吃的饭量。 小贝要连续吃 n 天的饭,有 n+1 个碗,第 i 个碗的容量为 ai,所有的碗每天都会重新盛满饭。小贝妈妈规定小贝在第 i 天要吃第 i、i+1 两碗饭。而小贝的饭量有限,每天最多只能吃 k 的饭量。但是小贝妈妈永远都觉得小贝吃的不够多,以至于可能会有小贝吃不下的剩饭。 浪费粮食可耻!现在小贝请你帮他调整序列 a 变为 a′,也就是减少一些碗的容量(可以不减),使得小贝每天吃饭的总量不会超过 k。但是减去的容量总和不能太大,否则小贝妈妈会觉得小贝是故意不想吃饭。 请你回答满足条件的序列 a′,表示调整之后每个碗的容量,并且减去的容量总和要最小。 不同的碗减去的容量可以不一样,最后每个碗的容量不可以是负数! 如果有多个满足条件的序列 a′ ,则输出 字典序最大 的那一个。 假设序列 x 和序列 y 都符合要求,则序列 x 的字典序比序列 y 的字典序大,当且仅当存在一个 i 满足 1≤i≤n+1 xi>yi 对于所有的 j(1≤j<i) 均有 xj=yj 输入格式 第 1 行 2 个正整数 n,k。 第 2 行 n+1 个正整数表示序列 a。 输出格式 输出一行 n+1 个整数,表示调整后的序列 a′。 样例 Input 1 5 6 3 4 2 7 3 1 Output 1 3 3 2 4 2 1 Input 2 5 6 7 4 3 7 2 8 Output 2 6 0 3 3 2 4 数据范围 前 50% : 1≤n≤2×103 1≤ai,k≤104 后 50% : 1≤n≤2×105 1≤ai,k≤104 样例解释 第1个样例中 第2个碗容量减少了1,第4个碗容量减少了3,第5个碗容量减少了1。 总共减少了5的容量,这是最少的减少容量之和。
最新发布
07-11
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值