例如:
水分子'h2o',它的构成是2个氢原子,1个氧原子,用对象表示为{h: 2, o: 1}。
再如氢氧化镁'mg(oh)2',用对象表示是{mg: 1, o: 2, h: 2}。
再来个复杂点的'k4[on(so3)2]2',表示为{k: 4, o: 14, n: 2, s: 4}。
这些分子式中,有可能出现很多成双成对的括号,包括圆的,方的,卷曲的,括号后面如果跟随了数字,那就表明,括号里的原子数量要乘以多少倍。例如’fe(no3)2’,它由一个铁原子,两个氮原子,六个氧原子组成。
这个题目的难点在于括号的处理上,有三种类型的括号,括号与括号之间有嵌套,有n对括号的情况。
//利用进出栈括号相抵,求对应括号的位置 function findbracket(str){ var stack = ["("]; for(var i=0;i<str.length;i++){ var chr = str.charat(i); if(chr === "("){ stack.push(chr); } else if(chr === ")"){ stack.pop(); } if(!stack.length){ return i; } } } function parsemolecule(formula) { //存放结果的hash var hash = {}; //先将所有的括号统一为圆括号 formula = formula.replace(/{/g ,"(") .replace(/}/g ,")") .replace(/\[/g ,"(") .replace(/\]/g ,")"); //遍历方法 var traverse = function(formula){ var str = ""; //存放数字之前的字符串 var prev = ""; for(var i=0;i<formula.length;i++){ var chr = formula.charat(i); //如果当前字符是数字 if(!isnan(chr)){ //如果右边的字符也是数字 //如"o12",十二个氧原子 if(!isnan(formula.charat(i+1))){ //"1" + "2" = "12" chr += formula.charat(i+1); i++; } //转化为数字 //"12" => 12 chr = chr - 0; //拼接"o" //=> "oooooooooooo" while(chr--){ str += prev; } } else if(chr === "("){ //剪切两个括号之间的内容,递归 //如"mg(oh)2" //"oh"递归 var temp = formula.slice(i+1); var pos = findbracket(temp); //=>"oh" prev = traverse(temp.slice(0,pos)); //右括号位置")" i = pos + i + 1; //如果右括弧右边不是数字,直接拼接"oh",无须相乘 if(isnan(formula.charat(i+1))){ str += prev; } }//如果当前字符右边是数字 else if(formula.charat(i+1) && !isnan(formula.charat(i+1))){ prev = chr; }//如果当前字符右边是小写字母,再右边是数字 else if(formula.charcodeat(i+1) >= 97 && formula.charcodeat(i+1) <= 122 && formula.charat(i+2) && !isnan(formula.charat(i+2))){ prev = chr + formula.charat(i+1); i++; } else{ str += chr; } } //如"mg(oh)2" //=> "mgohoh" return str; }; var result = traverse(formula); //将字符串遍历,在hash中存储 for(var i=0;i<result.length;i++){ var nextcode = result.charcodeat(i+1); //例如"mg","fe","cu"这样一个大写接一个小写的情况 if(nextcode >= 97 && nextcode <= 122){ var key = result.charat(i) + result.charat(i+1); i++; } else{ var key = result.charat(i); } if(hash[key]){ hash[key] = hash[key] + 1; } else{ hash[key] = 1; } } return hash; }
以上就是关于javascript解析化学分子式的代码实例分享的详细内容。
