Java BigInteger类详解与应用

article/2025/6/23 21:06:13

Java BigInteger类应用详解

BigInteger的构造方法:

对象一旦创建,内部的值不能发送改变

BigInteger常见的成员方法:

一、对象创建

BigInteger提供两种主要构造方式:

// 通过字符串构造
BigInteger num1 = new BigInteger("123456789012345678901234567890");
// 通过静态方法构造
BigInteger num2 = BigInteger.valueOf(999999999L);

二、基础运算方法
  1. 加法运算
BigInteger a = new BigInteger("123456789");
BigInteger b = BigInteger.valueOf(987654321L);
BigInteger sum = a.add(b); // 返回1111111110

     2.减法运算

BigInteger difference = b.subtract(a); // 返回864197532

     3.乘法运算

BigInteger product = a.multiply(b); // 返回121932631137021795

     4.除法运算

BigInteger quotient = b.divide(a); // 返回8

三、高级运算方法
  1. 模运算
BigInteger modResult = new BigInteger("100").mod(BigInteger.valueOf(3)); // 返回1

     2.幂运算

BigInteger power = BigInteger.valueOf(2).pow(100); // 计算2^100

     3.模幂运算

BigInteger modPowResult = new BigInteger("5").modPow(new BigInteger("3"), BigInteger.TEN); // (5^3)%10=125%10=5

四、数值比较
int comparison = new BigInteger("100").compareTo(new BigInteger("200")); // 返回-1(小于)
if (comparison < 0) {System.out.println("100小于200");
}

五、素数生成
// 生成1024位可能素数(概率性测试)
BigInteger prime = BigInteger.probablePrime(1024, new SecureRandom());

六、类型转换
// 安全转换(溢出时抛异常)
try {int safeInt = new BigInteger("2147483647").intValueExact();
} catch (ArithmeticException e) {System.err.println("超出int范围");
}

七、实用工具方法
  1. 最大公约数
BigInteger gcd = new BigInteger("12").gcd(new BigInteger("18")); // 返回6

     2.位运算

BigInteger shifted = BigInteger.ONE.shiftLeft(10); // 1左移10位=1024

     3.符号判断

int sign = new BigInteger("-100").signum(); // 返回-1

八、典型应用场景
  1. 密码学运算
// RSA密钥生成示例片段
BigInteger p = BigInteger.probablePrime(2048, new SecureRandom());
BigInteger q = BigInteger.probablePrime(2048, new SecureRandom());
BigInteger modulus = p.multiply(q);

     2.科学计算

// 计算100! 
BigInteger factorial = BigInteger.ONE;
for (int i = 1; i <= 100; i++) {factorial = factorial.multiply(BigInteger.valueOf(i));
}

九、注意事项
  1. 不可变性:所有运算均返回新对象
BigInteger original = BigInteger.TEN;
original.add(BigInteger.ONE); // 原对象仍为10
BigInteger newValue = original.add(BigInteger.ONE); // 新对象为11

     2.性能优化:避免频繁创建对象

// 低效写法
for (int i = 0; i < 1000; i++) {value = value.add(BigInteger.ONE);
}// 推荐优化
value = value.add(BigInteger.valueOf(1000));

     3.异常处理

try {BigInteger zero = BigInteger.ZERO;BigInteger result = value.divide(zero); // 触发ArithmeticException
} catch (ArithmeticException e) {System.err.println("除零错误");
}

十、扩展方法
  1. 数值转换
// 转换为二进制字符串
String binary = new BigInteger("255").toString(2); // 返回"11111111"// 十六进制转换
String hex = new BigInteger("255").toString(16); // 返回"ff"

     2.位操作

// 测试第5位(从右往左,0开始)
boolean bitStatus = new BigInteger("32").testBit(5); // 32=100000,第5位为1

总结:1.Biglnteger表示一个大整数。
           2.如何获取BigInteger的对象?
             Biglnteger b1 = Biglnteger.valueof(0.1);
             Biglnteger b1 = new Biglnteger("整数");

           3.常见操作

          

通过合理运用BigInteger类,开发者可以处理任意精度的整数运算需求,适用于金融计算、密码学、科学计算等领域。注意根据具体场景选择合适的方法,并做好异常处理与性能优化。


http://www.hkcw.cn/article/XvuniuCYZy.shtml

相关文章

LLM优化技术——Paged Attention

在Transformer decoding的过程中&#xff0c;需要存储过去tokens的所有Keys和Values&#xff0c;以完成self attention的计算&#xff0c;称之为KV cache。 &#xff08;1&#xff09;KV cache的大小 可以计算存储KV cache所需的内存大小&#xff1a; batch * layers * kv-he…

Java并发编程实战 Day 1:Java并发编程基础与线程模型

【Java并发编程实战 Day 1】Java并发编程基础与线程模型 开篇&#xff1a;系列定位与学习目标 欢迎来到为期30天的《Java并发编程实战》系列教程。本系列将从Java并发编程的基础知识讲起&#xff0c;逐步深入到高级特性与实战应用&#xff0c;帮助开发者构建高性能、可扩展的…

如何配置国内docker镜像源?

如何配置国内docker镜像源&#xff1f; 安装docker chattr -i /etc/passwd chattr -i /etc/shadow chattr -i /etc/group chattr -i /etc/gshadow# 下载slirp4netns rpm包 wget https://1407433742.rsc.cdn77.org/c7-extras.x86_64/slirp4netns/20200428221211/0.4.3-4.el7_…

【Ubuntu】摸鱼技巧之虚拟机环境复制

前言 提示&#xff1a;所有的操作都需要关闭虚拟机 如何快速在其它电脑布置&#xff0c;linux环境&#xff0c;如果我们有一个环境直接拷贝就有时间摸鱼呀。 1.直接复制简单粗暴 不做赘述&#xff0c;如果不会复制&#xff0c;那么请右击鼠标压缩复制 2.克隆虚拟机 2.1 …

C51单片机

1.单片机的概述 (1)微处理器(CPU) 运算器主要负责数据的算术运算和逻辑运算。 控制器:是发布命令的“决策机构”&#xff0c;负责协调和指挥整个计算机系统操作。 (2)存储器 程序存储器:用于存储程序和一些固定不变的常数和表格数据&#xff0c;一般由只读存储器(ROM)组成。…

介绍一种LDPC码译码器

介绍比特翻转译码原理以及LDPC码译码器的设计。 1 译码理论 比特翻转&#xff08;BF&#xff09;译码算法是硬判决算法的一种。 主要译码思想是&#xff1a;当有一个校验矩阵出错时&#xff0c;BF 算法认为在这个校验矩阵中一定至少存在一个位置的码字信息是错误的&#xff1…

Python简易音乐播放器开发教程

&#x1f4da; 前言 编程基础第一期《12-30》–音乐播放器是日常生活中常用的应用程序&#xff0c;使用Python和pygame库可以轻松实现一个简易的音乐播放器。本教程将详细讲解如何开发一个具有基本功能的音乐播放器&#xff0c;并解析其中涉及的Python编程知识点。 &#x1f6e…

【Docker项目实战篇】Docker部署PDF查看器PdfDing

【Docker项目实战篇】Docker部署PDD查看器PdfDing 一、PdfDing介绍1.1 PdfDing简介1.2 PdfDing主要特点1.3 主要使用场景 二、本次实践规划2.1 本地环境规划2.2 本次实践介绍 三、本地环境检查3.1 检查Docker服务状态3.2 检查Docker版本3.3 检查docker compose 版本 四、下载Pd…

AE 脚本表达式错误 Default ColorSelectionwhile (true){ break;} }

这个问题卡了我挺久的&#xff0c; 都没有解决&#xff0c; 暂时放在这&#xff0c;有解决办法来写。 也希望看到的朋友能帮忙解答

MyBatis01

目录 一、Mybatis 1.1 什么是 MyBatis&#xff1f; 1.2 ORM思想 Hibernate Mybatis&#xff08;ibatis&#xff09; 持久层技术对比 二、mybatis基础操作流程 2.1 引入jar包 2.2 mybatis核心配置文件 2.3 java文件和sql文件相分离 2.4 mybatis框架核心类&#xff0c…

C56-亲自实现字符串拷贝函数

一 strcpy简介 功能&#xff1a;将源字符串&#xff08;包括 \0&#xff09;复制到目标地址。 原型&#xff1a; char *strcpy(char *dest, const char *src);参数&#xff1a; dest&#xff1a;目标地址&#xff08;需足够大&#xff09;。src&#xff1a;源字符串&#xf…

设计模式——简单工厂模式(创建型)

摘要 本文主要介绍了简单工厂模式&#xff0c;包括其定义、结构、实现方式、适用场景、实战示例以及思考。简单工厂模式是一种创建型设计模式&#xff0c;通过工厂类根据参数决定创建哪一种产品类的实例&#xff0c;封装了对象创建的细节&#xff0c;使客户端无需关心具体类的…

山东大学软件学院项目实训-基于大模型的模拟面试系统-面试官和面试记录的分享功能(2)

本文记录在发布文章时&#xff0c;可以添加自己创建的面试官和面试记录到文章中这一功能的实现。 前端 首先是在原本的界面的底部添加了两个多选框&#xff08;后期需要美化调整&#xff09; 实现的代码&#xff1a; <el-col style"margin-top: 1rem;"><e…

【Hot 100】121. 买卖股票的最佳时机

目录 引言买卖股票的最佳时机我的解题 &#x1f64b;‍♂️ 作者&#xff1a;海码007&#x1f4dc; 专栏&#xff1a;算法专栏&#x1f4a5; 标题&#xff1a;【Hot 100】121. 买卖股票的最佳时机❣️ 寄语&#xff1a;书到用时方恨少&#xff0c;事非经过不知难&#xff01; 引…

《Spring Cloud Gateway 快速入门:从路由到自定义 Filter 的完整教程》​

1.网关介绍 在前面的学习中&#xff0c;我们通过Eureka和Nacos解决了辅助注册&#xff0c;使用Spring Cloud LoadBalance解决了负载均衡的问题&#xff0c;使用OpenFeign解决了远程调用的问题。 但是当前的所有微服务的接口都是直接对外暴露的&#xff0c;外部是可以直接访问…

高并发抽奖系统优化方案

引子 最近接触了一个抽奖的项目&#xff0c;由于用户量比较大&#xff0c;而且第三方提供的认证接口并发量有限&#xff0c;为了保证服务的高可用性&#xff0c;所以对高并限制发有一定的要求。经过一系列研究和讨论&#xff0c;做出了以下一些优化方案。 需求分析 根据用户量…

【Doris基础】Apache Doris中的Segment详解:存储与查询的核心组件

目录 1 Segment概述 1.1 什么是Segment 1.2 Segment的重要性 2 Segment的物理结构 2.1 Segment文件组成 2.2 列数据存储格式 3 Segment的生命周期 3.1 Segment创建 3.2 Segment合并(Compaction) 3.3 Segment过期与清理 4 Segment与查询处理 4.1 查询中的Segment剪枝…

JAVA中的枚举

代码示例 理论 枚举的行为多态 public enum MyLockStrategy {SKIP_FAST(){Overridepublic boolean tryLock(RLock lock, MyLock prop) throws InterruptedException {return lock.tryLock(0, prop.leaseTime(), prop.unit());}},FAIL_AFTER_RETRY_TIMEOUT(){Overridepublic bo…

电脑驱动程序更新工具, 3DP Chip 中文绿色版,一键更新驱动!

介绍 3DP Chip 是一款免费的驱动程序更新工具&#xff0c;可以帮助用户快速、方便地识别和更新计算机硬件驱动程序。 驱动程序更新工具下载 https://pan.quark.cn/s/98895d47f57c 软件截图 软件特点 简单易用&#xff1a;用户界面简洁明了&#xff0c;操作方便&#xff0c;…

day61—DFS—省份数量(LeetCode-547)

题目描述 有 n 个城市&#xff0c;其中一些彼此相连&#xff0c;另一些没有相连。如果城市 a 与城市 b 直接相连&#xff0c;且城市 b 与城市 c 直接相连&#xff0c;那么城市 a 与城市 c 间接相连。 省份 是一组直接或间接相连的城市&#xff0c;组内不含其他没有相连的城市…