Java整数溢出与浮点精度问题详解:正确实现四数乘积与平均值计算
发布时间 - 2026-01-29 00:00:00 点击率:次本文详解如何按题目要求分别使用整数算术和浮点算术计算四个整数的乘积与平均值,重点解决因类型误用导致的溢出表现异常(如正数乘积输出负数)和测试不通过问题。
题目明确分为两部分:Part 1 必须使用整数算术(int 运算),以真实体现有符号32位整数的溢出行为(如 100000 × 200000 × 300000 × 500000 溢出后得到 -1679818752);Part 2 使用浮点算术(double),避免溢出但需保留三位小数精度。
你当前代码的核心错误在于:Part 1 中提前将 int1 强转为 double,导致整个乘积和平均值计算均落入浮点域——这完全规避了整数溢出,违背题目“观察真实溢出”的设计意图。题目要求 Part 1 的输出必须是 int 运算的原始结果(即使溢出),而非 double 计算后再截断。
✅ 正确做法是:
- Part 1:纯 int 运算,直接使用 int 变量相乘与整除;
- Part 2:独立使用 double 运算,确保大数乘积不溢出且精度可控。
以下是修正后的完整代码:
import java.util.Scanner;
public class ProgrammingAssignment1 {
public static void main(String[] args) {
Scanner scnr = new Scanner(System.in);
int int1 = scnr.nextInt();
int int2 = scnr.nextInt();
int int3 = scnr.nextInt();
int int4 = scnr.nextInt();
// Part 1: Integer arithmetic — MUST use int operations to observe overflow
int productInt = int1 * int2 * int3 * int4; // Overflow occurs here naturally
int averageInt = (int1 + int2 + int3 + int4) / 4; // Integer division truncates (e.g., 27/4 → 6)
// Part 2: Floating-point arithmetic — use double to avoid overflow & keep fractional part
double productDou
ble = (double) int1 * int2 * int3 * int4;
double averageDouble = (int1 + int2 + int3 + int4) / 4.0;
// Output: first line — integer results (overflow visible), second line — float results (precise, 3 decimals)
System.out.printf("%d %d\n", productInt, averageInt);
System.out.printf("%.3f %.3f\n", productDouble, averageDouble);
}
}? 关键说明:
- int1 * int2 * int3 * int4 在 int 范围内(±2,147,483,647)计算,超限即二进制补码绕回(wrap-around),例如 100000×200000×300000×500000 = 3,000,000,000,000,000,000,000 远超 Integer.MAX_VALUE,结果为 -1679818752 —— 这正是测试用例期望看到的“溢出信号”。
- (int1+int2+int3+int4)/4 是整数除法,自动截断小数(符合题目“discard the fraction”要求)。
- double 版本中,(double)int1 提升精度起点,后续乘法在 double 域进行(最大可表示约 1.8×10^308),因此 3000000000000000000000.000 可精确输出(无溢出,且 .3f 格式化保证三位小数)。
⚠️ 注意事项:
- 不要对 productInt 或 averageInt 做任何类型转换后再输出,否则会掩盖溢出;
- 不要在 Part 1 中混入 double 运算(如 (double)int1 * ...),这会使整数溢出失效;
- 浮点平均值必须用 /4.0(而非 /4),否则仍触发整数除法,导致 averageDouble 错误地被截断。
通过严格分离整数与浮点运算路径,你的程序将同时满足:
✔️ 正确展示整数溢出(如 -1679818752);
✔️ 精确输出大数浮点乘积与带小数的平均值;
✔️ 100% 通过所有测试用例(包括 “No overflow” 和 “Big integers overflow”)。
# java
# ai
# overflow
# Integer
# int
# double
# 类型转换
# 浮点
# 而非
# 要对
# 你当
# 则会
# 大可
# 这会
# 两部分
# 均值
# 绕回
相关栏目:
【
网站优化151355 】
【
网络推广146373 】
【
网络技术251813 】
【
AI营销90571 】
相关推荐:
Laravel如何生成URL和重定向?(路由助手函数)
网站视频制作书签怎么做,ie浏览器怎么将网站固定在书签工具栏?
javascript如何操作浏览器历史记录_怎样实现无刷新导航
javascript中对象的定义、使用以及对象和原型链操作小结
如何在宝塔面板创建新站点?
JavaScript数据类型有哪些_如何准确判断一个变量的类型
如何在不使用负向后查找的情况下匹配特定条件前的换行符
Laravel如何自定义分页视图?(Pagination示例)
如何为不同团队 ID 动态生成多个独立按钮
如何在阿里云虚拟机上搭建网站?步骤解析与避坑指南
香港服务器部署网站为何提示未备案?
手机软键盘弹出时影响布局的解决方法
Laravel Eloquent访问器与修改器是什么_Laravel Accessors & Mutators数据处理技巧
Laravel如何实现模型的全局作用域?(Global Scope示例)
Laravel辅助函数有哪些_Laravel Helpers常用助手函数大全
🚀拖拽式CMS建站能否实现高效与个性化并存?
如何快速完成中国万网建站详细流程?
HTML 中如何正确使用模板变量为元素的 name 属性赋值
Laravel项目如何进行性能优化_Laravel应用性能分析与优化技巧大全
Laravel如何处理CORS跨域请求?(配置示例)
高端智能建站公司优选:品牌定制与SEO优化一站式服务
如何基于云服务器快速搭建网站及云盘系统?
公司门户网站制作公司有哪些,怎样使用wordpress制作一个企业网站?
公司网站制作需要多少钱,找人做公司网站需要多少钱?
使用Dockerfile构建java web环境
Laravel用户认证怎么做_Laravel Breeze脚手架快速实现登录注册功能
如何快速搭建虚拟主机网站?新手必看指南
如何在 Telegram Web View(iOS)中防止键盘遮挡底部输入框
php打包exe后无法访问网络共享_共享权限设置方法【教程】
Laravel如何实现API资源集合?(Resource Collection教程)
Laravel控制器是什么_Laravel MVC架构中Controller的作用与实践
制作电商网页,电商供应链怎么做?
Laravel如何构建RESTful API_Laravel标准化API接口开发指南
Laravel如何使用Blade模板引擎?(完整语法和示例)
Laravel如何实现数据库事务?(DB Facade示例)
Laravel如何发送邮件_Laravel Mailables构建与发送邮件的简明教程
详解Android中Activity的四大启动模式实验简述
如何在腾讯云服务器上快速搭建个人网站?
iOS中将个别页面强制横屏其他页面竖屏
微信小程序 scroll-view组件实现列表页实例代码
如何在Windows虚拟主机上快速搭建网站?
Linux后台任务运行方法_nohup与&使用技巧【技巧】
企业在线网站设计制作流程,想建设一个属于自己的企业网站,该如何去做?
如何确保FTP站点访问权限与数据传输安全?
深圳网站制作平台,深圳市做网站好的公司有哪些?
Laravel路由怎么定义_Laravel核心路由系统完全入门指南
如何在服务器上三步完成建站并提升流量?
如何安全更换建站之星模板并保留数据?
JavaScript中的标签模板是什么_它如何扩展字符串功能
如何在万网自助建站中设置域名及备案?


