算法Bug

记录一些自己做算法时遇到的Bug

1.数据超出int最大值

for(int i = 0; i < 1 << n; i++){
            Arrays.fill(f[i], Integer.MAX_VALUE) ;
        }

用上面代码给数组f填充最大值的时候,要注意后面对f[i][j]进行+运算的时候会超出int能表示的最大值。

解决办法:

1.给赋的值除以2(推荐)

for(int i = 0; i < 1 << n; i++){
            Arrays.fill(f[i], Integer.MAX_VALUE >> 1) ;
        }

2.使用long数组,不过使用long数组的话要注意内存溢出问题,即java.lang.OutOfMemoryError:Java heap space

2. devc++ value of xxx too large for field of 4 bytes at xxx

原因:开的数组太大了。比如开一个长度为10^9 的int数组占用的内存会超过512MB。

3. 使用scanf输入多个数据,当数据类型不一致时,要按照题目给定的数据格式进行读取。

比如输入数据为:-1 1 A,对应的输入格式应为"%d %d %c",中间的空格也不能省略。

  • 8
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值