JS一个算法题

Wesley13
• 阅读 707

题目:实现超出整数存储范围的两个大整数想加function(a,b)。注意:参数a和b以及函数返回值都是字符串。

目的:考算法, 基本逻辑。

我实现的基本思路是:

①两个数字字符串长度补成一样,用字符串'0’补位,比如 a='1111',b='22',b用'0'补位成='0022'.

②分3中情况处理,初始值的长度比较,,a的长度大于b的长度,b的长度大于a的长度,a的长度等于b的长度

③初始值的长度比较,,a的长度大于b的长度,补位比较简单,再用两个空数组push进去,push的时候都parseInt( )转换成数字,为后面好计算

④再准备个空数组,for循环 把③的两个数组里对应的索引值的值想加后的值push进这个空数组,标记数组④

⑤数组④里的值再用比较排序的原理再处理下,差不多就出来了,不废话了,直接上代码

 1 function add(a,b){
 2     var arr=[];
 3     var len=a.length>b.length?a.length:(a.length<b.length?b.length:a.length);
 4     var n=a.length>b.length?a.length-b.length:b.length-a.length;
 5     if(a.length===b.length){
 6         for(var i=0;i<len;i++){
 7             arr.unshift(parseInt(a[i])+parseInt(b[i]))    
 8         }    
 9     }else{
10         var str='';
11         for(var i=0;i<n;i++){
12             str+='0';
13         }
14         var _this= a.length>b.length ? str+b : str+a ;
15         if(a.length>b.length){
16             for(var i=0;i<len;i++){
17                 arr.unshift(parseInt(a[i])+parseInt(_this[i]))
18             }
19         }else{
20             for(var i=0;i<len;i++){
21                 arr.unshift(parseInt(b[i])+parseInt(_this[i]))
22             }
23         }
24     }
25     for(var i=0;i<len-1;i++){
26         for(var j=0;j<len-1-i;j++){
27             if(arr[j]>=10){
28                 var temp=arr[j]-10;
29                 arr[j]=temp;
30                 arr[j+1]=arr[j+1]+1;
31             }else{
32                 arr[j]=arr[j];
33             }
34         }
35     }
36 
37     return arr.reverse().join('');
38 }
39 
40 var a='111';
41 var b='22275676575'
42 console.log(add(a,b))
43 console.log(parseInt(a)+parseInt(b))

再优化了下:

 1 function add(a,b){
 2     var arr=[];
 3     var len=a.length>b.length?a.length:(a.length<b.length?b.length:a.length);
 4     var n=a.length>b.length?a.length-b.length:b.length-a.length;
 5     if(a.length===b.length){
 6         for(var i=0;i<len;i++){
 7             arr.unshift(parseInt(a[i])+parseInt(b[i]))    
 8         }    
 9     }else{
10         var _this= a.length>b.length ? b.padStart(len,'0') : a.padStart(len,'0') ;
11         if(a.length>b.length){
12             for(var i=0;i<len;i++){
13                 arr.unshift(parseInt(a[i])+parseInt(_this[i]))
14             }
15         }else{
16             for(var i=0;i<len;i++){
17                 arr.unshift(parseInt(b[i])+parseInt(_this[i]))
18             }
19         }
20     }
21     for(var i=0;i<len-1;i++){
22         for(var j=0;j<len-1-i;j++){
23             if(arr[j]>=10){
24                 var temp=arr[j]-10;
25                 arr[j]=temp;
26                 arr[j+1]=arr[j+1]+1;
27             }else{
28                 arr[j]=arr[j];
29             }
30         }
31     }
32     return arr.reverse().join('');
33 }
34 
35 var a='111';
36 var b='22275676575'
37 console.log(add(a,b))
38 console.log(parseInt(a)+parseInt(b))

 小数精度处理方法:超小值保存 需要保存成字符串

 1 function add(a,b){
 2   var aStr=a.toString();
 3   var bStr=b.toString();
 4   var aLen=aStr.length;
 5   var bLen=bStr.length;
 6   var resStr=aLen>bLen?aStr:bStr;
 7   var resLen=aLen>bLen?aLen:bLen;
 8   var n= resLen - resStr.indexOf('.')-1;
 9   return (a*10*n+b*10*n)/(10*n)
10 }
11 console.log(add(0.1,0.2))//0.3
12 console.log(add(0.1,0.00000002))//0.10000002
13 console.log(add(0.01,0.0000002))//0.0100002
点赞
收藏
评论区
推荐文章
blmius blmius
3年前
MySQL:[Err] 1292 - Incorrect datetime value: ‘0000-00-00 00:00:00‘ for column ‘CREATE_TIME‘ at row 1
文章目录问题用navicat导入数据时,报错:原因这是因为当前的MySQL不支持datetime为0的情况。解决修改sql\mode:sql\mode:SQLMode定义了MySQL应支持的SQL语法、数据校验等,这样可以更容易地在不同的环境中使用MySQL。全局s
皕杰报表之UUID
​在我们用皕杰报表工具设计填报报表时,如何在新增行里自动增加id呢?能新增整数排序id吗?目前可以在新增行里自动增加id,但只能用uuid函数增加UUID编码,不能新增整数排序id。uuid函数说明:获取一个UUID,可以在填报表中用来创建数据ID语法:uuid()或uuid(sep)参数说明:sep布尔值,生成的uuid中是否包含分隔符'',缺省为
待兔 待兔
6个月前
手写Java HashMap源码
HashMap的使用教程HashMap的使用教程HashMap的使用教程HashMap的使用教程HashMap的使用教程22
Jacquelyn38 Jacquelyn38
3年前
2020年前端实用代码段,为你的工作保驾护航
有空的时候,自己总结了几个代码段,在开发中也经常使用,谢谢。1、使用解构获取json数据let jsonData  id: 1,status: "OK",data: 'a', 'b';let  id, status, data: number   jsonData;console.log(id, status, number )
Stella981 Stella981
3年前
KVM调整cpu和内存
一.修改kvm虚拟机的配置1、virsheditcentos7找到“memory”和“vcpu”标签,将<namecentos7</name<uuid2220a6d1a36a4fbb8523e078b3dfe795</uuid
Wesley13 Wesley13
3年前
mysql设置时区
mysql设置时区mysql\_query("SETtime\_zone'8:00'")ordie('时区设置失败,请联系管理员!');中国在东8区所以加8方法二:selectcount(user\_id)asdevice,CONVERT\_TZ(FROM\_UNIXTIME(reg\_time),'08:00','0
Stella981 Stella981
3年前
JS 对象数组Array 根据对象object key的值排序sort,很风骚哦
有个js对象数组varary\{id:1,name:"b"},{id:2,name:"b"}\需求是根据name或者id的值来排序,这里有个风骚的函数函数定义:function keysrt(key,desc) {  return function(a,b){    return desc ? ~~(ak
Stella981 Stella981
3年前
JavaScript常用函数
1\.字符串长度截取functioncutstr(str,len){vartemp,icount0,patrn/^\x00\xff/,strre"";for(vari
Wesley13 Wesley13
3年前
MySQL部分从库上面因为大量的临时表tmp_table造成慢查询
背景描述Time:20190124T00:08:14.70572408:00User@Host:@Id:Schema:sentrymetaLast_errno:0Killed:0Query_time:0.315758Lock_
Python进阶者 Python进阶者
1年前
Excel中这日期老是出来00:00:00,怎么用Pandas把这个去除
大家好,我是皮皮。一、前言前几天在Python白银交流群【上海新年人】问了一个Pandas数据筛选的问题。问题如下:这日期老是出来00:00:00,怎么把这个去除。二、实现过程后来【论草莓如何成为冻干莓】给了一个思路和代码如下:pd.toexcel之前把这