加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 大数据 > 正文

大数相乘

发布时间:2020-12-14 01:37:46 所属栏目:大数据 来源:网络整理
导读:双层循环算法:时间复杂度O(N^2) ;空间复杂度:O(m+n); 下面是源码: package algorithm; public class BigNumMul { public static void main(String args[]){ String a="999"; String b="99999999"; String r=mul(a,b); System.out.println(r); } public sta

双层循环算法:时间复杂度O(N^2) ;空间复杂度:O(m+n);

下面是源码:

package algorithm; public class BigNumMul { public static void main(String args[]){ String a="999"; String b="99999999"; String r=mul(a,b); System.out.println(r); } public static String mul(String a,String b){ int m=a.length(); int n=b.length(); byte[] aa=a.getBytes(); byte[] bb=b.getBytes(); byte[] result=new byte[m+n]; for(int index=0;index<result.length;index++) result[index]='0'; int mul; int add; for(int i=m-1;i>=0;i--){ mul=0; add=0; for(int j=n-1;j>=0;j--){ int temp1=(aa[i]-'0')*(bb[j]-'0')+mul; mul=temp1/10; temp1=temp1%10; int temp2=result[i+j+1]-'0'+temp1+add; add=temp2/10; result[i+j+1]=(byte) (temp2%10+'0'); } result[i]=(byte)(mul+add+'0'); } String s=new String(result); return s; } }

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读