Java的学习与java大数运算

之前就学过一点java,但太久没用知识点早就还给书本,之前在实验室搞到一本java的书,今天来重新温习一下
java的语法大部分和c++语言是一样的,入门非常快,所以在这里基础语句的用法就省略了
输出:

System.out.println() 输出信息后追加一个换行
System.out.print()输出之后不追加换行

string:

str.IndexOf()//返回搜索的字符或字符串首次出现的位置
str.lastIndexOf()//返回搜索的字符或字符串最后一次的位置
charAt()//可将指定索引处的字符返回
trim()//返回字符串的副本,忽略前导空格和尾部空格
startsWith()//判断当前字符串对象的前缀是否为参数指定的字符串
endWith()//判断当前字符串是否为以给定的子字符串结束
toLowerCase()//把所有字符从大写字母改成小写字母
toUpperCase()//把所有字符从小写字母改成大写字母

java大数运算

在java中有个BigInteger类型,支持任意精度的整数,也就是说在运算中BigInteger类型可以准确地表示任何大小的整数值而不会丢失任何数据

public BigInteger add(BigInteger val)//做加法运算
public BigInteger subtract(BigInteger val)//做减法运算
public BigInteger multiply(BigInteger val)//做乘法运算
public BigInteger divide(BigInteger val)//做除法运算
public BigInteger remainder(BigInteger val)//做取余运算
public BigInteger negate(BigInteger val)//取相反数

BIgDecimal加入了小数的概念,支持任何精度的定点数,可以用它来精确计算货币值

public BigDecimal add(BigDecimal augend):做加法操作
subtract()做减法操作
multiply()做乘法操作
divide()做除法操作

大数阶乘:

import java.math.BigDecimal;
import java.util.Scanner;public class Main{
public static BigDecimal factorial(BigDecimal n){ 
BigDecimal bd1 = new BigDecimal(1);//BigDecimal类型的1 
BigDecimal bd2 = new BigDecimal(2);//BigDecimal类型的2 
BigDecimal result = bd1;//结果集,初值取1 
while(n.compareTo(bd1) > 0){//参数大于1,进入循环 
result = result.multiply(n.multiply(n.subtract(bd1)));//实现result*(n*(n-1)) 
n = n.subtract(bd2);//n-2后继续 
} 
return result; 
}public static void main(String[] args){System.out.println("请输入阶乘数:");Scanner sc = new Scanner(System.in); BigDecimal n = sc.nextBigDecimal(); sc.close();System.out.print(n + "!=" + factorial(n));}
}
/*
大数的加减运算不同于普通整数的加减乘除运算
加—— a+b: a=a.add(b);
减—— a-b: a=a.subtract(b);
乘—— a*b: a=a.multiply(b);
除—— a/b: a=a.divide(b);
求余—a%b: a=a.mod(b);
转换—a=b: b=BigInteger.valueOf(a);
比较 if (ans.compareTo(x) == 0)//比较System.out.println("相等");
System.out.println("a + b = "+ans_add); // 这里的‘+’ (第二个) 是连接的意思
*/
package wkf;
import java.util.*;
import java.math.*;
public class Main {public static void main(String args[]) {Scanner cin = new Scanner(System.in);BigInteger a,b,x,y;BigInteger ans_add,ans_sub,ans_mul,ans_div,ans_mod;a=cin.nextBigInteger();b=cin.nextBigInteger();ans_add = a.add(b); //a+bans_sub = a.subtract(b); //a-bans_mul = a.multiply(b); //a*bans_div = a.divide(b); //a/bans_mod = a.mod(b); //a%bx=BigInteger.valueOf(1);//转换System.out.println("a + b = "+ans_add);System.out.println("a - b = "+ans_sub);System.out.println("a * b = "+ans_mul);System.out.println("a / b = "+ans_div);System.out.println("a % b = " + ans_mod);System.out.println(x);if (a.compareTo(b) == 0)//比较System.out.println("相等");elseSystem.out.println("不相等");}
}

大数加法:

import java.math.BigInteger;
import java.util.*;
import java.io.*;public class Main
{public static void main(String args[]){Scanner in = new Scanner(System.in);int n = in.nextInt();		for(int i = 1; i <= n; ++i){BigInteger a = in.nextBigInteger();BigInteger b = in.nextBigInteger();BigInteger ans = a.add(b);System.out.println("Case " + i + ":");System.out.println(a + " + " + b + " = " +ans);}}
}

之后继续更新

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/319201.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【DP】【容斥】Nice to Meet You(AT3634)

正题 luogu AT3634 题目大意 给你一个图&#xff0c;让你给图上的边定方向&#xff0c;问1,2两个点可以到同一个点的方案数 解题思路 直接求可以到同一个点不好求&#xff0c;可以用总方案数减去不合法方案数&#xff0c;即到不了同一个点的方案数 那么就是有若干点把1,2分…

codeforces1453 E. Dog Snacks

E. Dog Snacks Heltion大佬题解 fuf_ufu​表示节点uuu到最近叶子节点的距离。 首先不难发现&#xff0c;考虑一棵子树根节点为uuu&#xff0c;一定每次都把一整棵子树上的食物吃完&#xff0c;然后再去别的子树。 由于每次狗总是先去离他最近的节点&#xff0c;如果我们把一…

工厂参观记:.NET Core 中 HttpClientFactory 如何解决 HttpClient 臭名昭著的问题

在 .NET Framework 与 .NET Core 中 HttpClient 有个臭名昭著的问题&#xff0c;HttpClient 实现了 IDispose 接口&#xff0c;但当你 Dispose 它时&#xff0c;它不会立即关闭所使用的 tcp 连接&#xff0c;而是将 tcp 连接置为 TIME_WAIT 状态&#xff0c;240秒&#xff08;4…

数据结构题(莫队算法)

数据结构题 题目&#xff1a; 问在区间[l,r]和[l1,r1]内x的出现次数的乘积是多少&#xff1f; 题解&#xff1a; 莫队算法的模板题 关于莫队算法你可以参考这个 我这里简单的说说我对莫队的理解&#xff1a; 莫队是一个优雅的暴力&#xff0c;就是将原本复杂度不能过的程序…

AT4120-[ARC096D]Sweet Alchemy【贪心,背包】

正题 题目链接:https://www.luogu.com.cn/problem/AT4120 题目大意 给出nnn个物品和一个容量mmm&#xff0c;第iii个物品体积为cic_ici​。除了第一个物品每个物品还有一个pi(pi<i)p_i(p_i<i)pi​(pi​<i)表示如果pip_ipi​个物品选择了xxx个&#xff0c;第iii个物品…

【DP】Table(CF232B)

正题 luogu CF232B 题目大意 给你一个 nmn\times mnm 的网格&#xff0c;问你有多少种放点方案可以满足每个 nnn\times nnn 的网格内都恰好有 kkk 个点 解题思路 不难发下&#xff0c;nnn\times nnn 的格子往下移一行&#xff0c;新的一行和刚过的一行点的数量一样 那么设 …

枚举子集dp

枚举子集 二进制枚举子集下面代码就是枚举的s的子集&#xff08;二进制状态压缩&#xff09; for(int is;i;i(i-1)&s){//i表示的就是s的子集}枚举所有子集的子集的时间复杂度 比如一个有n个元素构成的集合&#xff0c;子集的数量是2n2^n2n&#xff0c;现要求枚举所有子集的…

数列互质(莫队算法)

数列互质 题目描述 给出一个长度为 n 的数列 { a[1] , a[2] , a[3] , … , a[n] }&#xff0c;以及 m 组询问 ( l[i] , r[i] , k[i])。 求数列下标区间在 [ l[i] , r[i] ] 中有多少数在该区间中的出现次数与 k[i] 互质&#xff08;最大公约数为1&#xff09;。 输入描述: 第一…

P3211-[HNOI2011]XOR和路径【高斯消元】

正题 题目链接:https://www.luogu.com.cn/problem/P3211 题目大意 一个nnn个点mmm条边的无向图&#xff0c;从111到nnn随机游走。求期望路径异或和。 2≤n≤100,1≤m≤1042\leq n\leq 100,1\leq m\leq 10^42≤n≤100,1≤m≤104 解题思路 因为是异或的期望&#xff0c;很难直…

【随机】Ghd(CF364D)

正题 luogu CF364D 题目大意 给你一个大小为n的集合&#xff0c;选择一个至少为一半的子集&#xff0c;另其gcd最大 解题思路 由于数字个数很多&#xff0c;考虑随机 随机选10个数&#xff0c;对于每个数&#xff0c;先处理出约数&#xff0c;然后求出所有数和当前数的gcd&…

ASP.NET Core2读写InfluxDB时序数据库

在我们很多应用中会遇到有一种基于一系列时间的数据需要处理&#xff0c;通过时间的顺序可以将这些数据点连成线&#xff0c;再通过数据统计后可以做成多纬度的报表&#xff0c;也可通过机器学习来实现数据的预测告警。而时序数据库就是用于存放管理这种有着时间顺序数据的&…

Nature 新研究发布,GPT 驱动的机器人化学家能够自行设计和进行实验,这对科研意味着什么?

文章目录 前言揭秘Coscientist不到四分钟&#xff0c;设计并改进了程序能力越大&#xff0c;责任越大 前言 有消息称&#xff0c;AI 大模型 “化学家” 登 Nature 能够自制阿司匹林、对乙酰氨基酚、布洛芬&#xff0c;甚至连复杂的钯催化交叉偶联反应&#xff0c;也能完成。 …

珂朵莉的约数

来源&#xff1a;牛客网&#xff1a; 题目描述 珂朵莉给你一个长为n的序列&#xff0c;有m次查询 每次查询给两个数l,r 设s为区间[l,r]内所有数的乘积 求s的约数个数mod 1000000007 输入描述: 第一行两个正整数n,m 第二行一个长为n的序列 之后m行每行两个数l和r 输出描述…

AtCoder Regular Contest 110 E.Shorten ABC——坑

计数渣渣不会啊 下学期学概率论与数理统计不知道会不会提升数数能力 E.Shorten ABC 当B数组确定后&#xff0c;不难发现就是所问问题即从B序列选出A序列的方案数。 等效于那么从mn中选出sn个小球&#xff0c;我们假设多选的n个小球是一个隔板&#xff0c;隔出数组A&#xff0…

【DP】Rotating Substrings(CF1363F)

正题 luogu CF1363F 题目大意 给你一个字符串&#xff0c;你以旋转其中一个字串&#xff08;将最后一给点移到前面&#xff0c;然后整体向后移一位&#xff09;&#xff0c;问最少要多少布可以到目标字符串 解题思路 设 fi,jf_{i,j}fi,j​ 为 sss 中的前 iii 个字符构成 ttt…

P3348-[ZJOI2016]大森林【LCT】

正题 题目链接:https://www.luogu.com.cn/problem/P3348 题目大意 有nnn棵树开始只有一个编号为111的节点且为标记点。mmm次操作要求支持 在l∼rl\sim rl∼r的树中的标记点下面加入一个新的编号的节点将l∼rl\sim rl∼r的树上的标记点改为xxx&#xff08;如果没有节点xxx就不…

SmartCode 常见问题

SmartCode 能干什么&#xff1f;SmartCode IDataSource -> IBuildTask -> IOutput > Build EverythingSmartCode的执行流是 数据源->构建任务->输出&#xff0c;也就是说应用场景非常广泛。从DB读取数据结构&#xff0c;最终生成整个解决方案代码生成器&#x…

[数论]线性筛——约数个数与约数和

参考博客 参考博客 参考博客 这个讲的挺好 预备知识点&#xff1a; 大于1的数n可以分解质因数&#xff1a; np1a1p2a2p3a3*…*pka n的约数的个数是(a11) * (a21) * (a31)…(ak1) 我们先用线性筛来筛出素数 bool mark[maxn]; int prim[maxn]; int cnt; void initial() {cnt0;f…

F. Paper Grading(Trie树+dfs序+二维数点)

F. Paper Grading 大佬题解 一般关于前缀的问题基本都是Trie树。 首先将所给字符串建立一棵Trie树&#xff0c;Trie能够解决一个字符串在一个字符串集合中出现的次数&#xff0c;而查询前缀次数只需要找到Trie树中所给字符末尾的位置&#xff0c;那么其子树中打标记的次数即前…

AT2164-[AGC006C]Rabbit Exercise【差分,倍增,数学期望】

正题 题目链接:https://www.luogu.com.cn/problem/AT2164 题目大意 nnn只兔子编号为1∼n1\sim n1∼n&#xff0c;第iii只在坐标轴xix_ixi​处。然后mmm次跳跃&#xff0c;每次给出aia_iai​&#xff0c;编号为aia_iai​的兔子会等概率的选取ai−1a_{i-1}ai−1​和ai1a_{i1}ai1…