实现两个超长正整数相加

本文详细探讨如何实现两个非常大的正整数相加的算法,涉及字符串处理和数学逻辑,适用于处理超出普通整型范围的数值计算。
摘要由CSDN通过智能技术生成

实现两个超长正整数相加

public class AddString {
	 public String AddLongInteger(String addend, String augend) {
		 /**
		  * 保证addend始终为较长的字符串
		  */
		 if(addend.length() < augend.length()) {
			 String t = addend;
			 addend = augend;
			 augend = t;
		 }
		 int n1 = addend.length();
		 int n2 = augend.length();
		 /**
		  * 长度对齐
		  */
		 StringBuffer t = new StringBuffer();
		 for(int i = 0;i < n1-n2;i++) {
			 t.append(0);
		 }
		 augend = t.append(augend).toString();

		 /**
		  * 相加结果保存在ch字符数组中
		  */
		 char[] ch = new char[n1+1];
		 for(int i = 0;i < n1+1;i++) {
			 ch[i] = '0';
		 }
		 
		 for(int i = n1;i > 0;i--) {
			 /**
			  * 取出相加的数
			  */
			 int a = addend.charAt(i-1)-'0';
			 int b = augend.charAt(i-1)-'0';
			 //转为字符
			 int c = ch[i]-'0'+a+b;
			 //ch[i]本位和 ch[i-1]进位
			 ch[i] = (char)(c%1
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值