JS一个算法题
题目:实现超出整数存储范围的两个大整数想加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进这个空数组,标记数组④
⑤数组④里的值再用比较排序的原理再处理下,差不多就出来了,不废话了,直接上代码
function add(a,b){
var arr=[];
var len=a.length>b.length?a.length:(a.length<b.length?b.length:a.length);
var n=a.length>b.length?a.length-b.length:b.length-a.length;
if(a.length===b.length){
for(var i=0;i<len;i++){
arr.unshift(parseInt(a[i])+parseInt(b[i]))
}
}else{
var str='';
for(var i=0;i<n;i++){
str+='0';
}
var _this= a.length>b.length ? str+b : str+a ;
if(a.length>b.length){
for(var i=0;i<len;i++){
arr.unshift(parseInt(a[i])+parseInt(_this[i]))
}
}else{
for(var i=0;i<len;i++){
arr.unshift(parseInt(b[i])+parseInt(_this[i]))
}
}
}
for(var i=0;i<len-1;i++){
for(var j=0;j<len-1-i;j++){
if(arr[j]>=10){
var temp=arr[j]-10;
arr[j]=temp;
arr[j+1]=arr[j+1]+1;
}else{
arr[j]=arr[j];
}
}
} return arr.reverse().join('');
} var a='111';
var b='22275676575'
console.log(add(a,b))
console.log(parseInt(a)+parseInt(b))
再优化了下:
function add(a,b){
var arr=[];
var len=a.length>b.length?a.length:(a.length<b.length?b.length:a.length);
var n=a.length>b.length?a.length-b.length:b.length-a.length;
if(a.length===b.length){
for(var i=0;i<len;i++){
arr.unshift(parseInt(a[i])+parseInt(b[i]))
}
}else{
var _this= a.length>b.length ? b.padStart(len,'0') : a.padStart(len,'0') ;
if(a.length>b.length){
for(var i=0;i<len;i++){
arr.unshift(parseInt(a[i])+parseInt(_this[i]))
}
}else{
for(var i=0;i<len;i++){
arr.unshift(parseInt(b[i])+parseInt(_this[i]))
}
}
}
for(var i=0;i<len-1;i++){
for(var j=0;j<len-1-i;j++){
if(arr[j]>=10){
var temp=arr[j]-10;
arr[j]=temp;
arr[j+1]=arr[j+1]+1;
}else{
arr[j]=arr[j];
}
}
}
return arr.reverse().join('');
} var a='111';
var b='22275676575'
console.log(add(a,b))
console.log(parseInt(a)+parseInt(b))
小数精度处理方法:超小值保存 需要保存成字符串
function add(a,b){
var aStr=a.toString();
var bStr=b.toString();
var aLen=aStr.length;
var bLen=bStr.length;
var resStr=aLen>bLen?aStr:bStr;
var resLen=aLen>bLen?aLen:bLen;
var n= resLen - resStr.indexOf('.')-1;
return (a*10*n+b*10*n)/(10*n)
}
console.log(add(0.1,0.2))//0.3
console.log(add(0.1,0.00000002))//0.10000002
console.log(add(0.01,0.0000002))//0.0100002
JS一个算法题的更多相关文章
- 19道常见的JS面试算法题
最近秋招也做了多多少少的面试题,发现除了基础知识外,算法还是挺重要的.特意整理了一些常见的算法题,添加了自己的理解并实现. 除此之外,建议大家还可以刷刷<剑指offer>.此外,左神在牛客 ...
- FCC JS基础算法题(1):Factorialize a Number(计算一个整数的阶乘)
题目描述: 如果用字母n来代表一个整数,阶乘代表着所有小于或等于n的整数的乘积.阶乘通常简写成 n!例如: 5! = 1 * 2 * 3 * 4 * 5 = 120. 算法: function fac ...
- js的算法题
1.统计一个字符串中出现最多的字母 给出一个字符串,统计出现次数最多的字母.如:“wqeqwhixswiqhdxsq”,其中出现最多的是q. js算法的实现 function findMax(str) ...
- JS基础算法题(二)
1.1 数组去重的五种方法 数组去重:将数组中重复的元素去掉 JS数组没有删除具体元素的删除(只能删掉值,删不掉元素的索引),可以使用另外一个结构来进行存储 新数组 新对象 JS数组虽然本质可以删除第 ...
- FCC JS基础算法题(5):Return Largest Numbers in Arrays(找出多个数组中的最大数)
题目描述: 找出多个数组中的最大数右边大数组中包含了4个小数组,分别找到每个小数组中的最大值,然后把它们串联起来,形成一个新数组.提示:你可以用for循环来迭代数组,并通过arr[i]的方式来访问数组 ...
- FCC JS基础算法题(2):Check for Palindromes(检查回文字符串)
题目描述: 如果给定的字符串是回文,返回true,反之,返回false.如果一个字符串忽略标点符号.大小写和空格,正着读和反着读一模一样,那么这个字符串就是palindrome(回文).注意你需要去掉 ...
- FCC JS基础算法题(0):Reverse a String(翻转字符串)
题目描述: 先把字符串转化成数组,再借助数组的reverse方法翻转数组顺序,最后把数组转化成字符串.你的结果必须得是一个字符串. 算法: function reverseString(str) { ...
- JS刷算法题:二叉树
Q1.翻转二叉树(easy) 如题所示 示例: 输入: 4 / \ 2 7 / \ / \ 1 3 6 9 输出: 4 / \ 7 2 / \ / \ 9 6 3 1 来源:力扣(LeetCode) ...
- FCC JS基础算法题(4):Title Case a Sentence(句中单词首字母大写)
题目描述: 确保字符串的每个单词首字母都大写,其余部分小写.像'the'和'of'这样的连接符同理. 算法: function titleCase(str) { // 转小写及分割成数组 var st ...
随机推荐
- java 实现websocket的三种方式
Java中实现websocket常见有以下三种方式: 使用tomcat的websocket实现,需要tomcat 7.x,JEE7的支持. 使用spring的websocket,spring与webs ...
- 家庭记账本web开发
这个系统的整体结构: GitHub:https://github.com/lq1998lq/Test.git com.action包: package com.action; import java. ...
- windows下搭建voip服务器
软件: yate-6.0.0-1-setup.exe 服务端,里面也有个客户端 eyeBeam.exe 客户端 步骤: 失败....
- sql server 附加只有mdf的数据库文件
有时候SQL Server意外断电会导致SQL Server的ldf日志文件丢失或者损坏,这个时候你如果直接附加mdf文件到SQL Server会失败,这里提供一个方法可以还原只有mdf的数据库文件, ...
- mobx 知识点
antd+mobx 项目例子:https://github.com/cag2050/antd_mobx_demo 在 create-react-app 创建的项目中,使用 mobx:https://s ...
- navicat外键设置
https://blog.csdn.net/qq_32486599/article/details/73497810
- arttemplate记录
1,传到前端显示数据,最好用一个包装类,否则不知道怎么拿值 这样是忽略类名,直接从data属性入手,然后用点操作符 如果data是个list,可以用这个形式
- TP5 中引入第三方类库
通过了解tp5的目录结构,我们知道其中有两个目录是纺织扩展类库文件的. extend是放置自定义或者其他类文件的. vendor目录是放置composer类库文件的. 当我们的第三方类库文件是下载的, ...
- C# 中数据类型以及结构
值类型:int.double.char.bool...,结构. 引用类型:类(string).接口.数组 Class1.cs using System; using System.Collection ...
- 推荐四款 Bug 管理系统,最适合你的才是最好的!
转载自:https://www.jianshu.com/p/e7d3121eaaec 在这个移动互联网的时代,每天都会涌入大量新的 App,想要留住你的用户,必须时刻保持产品创新与系统的稳定.对于 ...