给定一个化学分子式的字符串,统计每一种元素原子的数量。
例如:
水分子'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’,它由一个铁原子,两个氮原子,六个氧原子组成。
eSiteGroup站群管理系统是基于eFramework低代码开发平台构建,是一款高度灵活、可扩展的智能化站群管理解决方案,全面支持SQL Server、SQLite、MySQL、Oracle等主流数据库,适配企业级高并发、轻量级本地化、云端分布式等多种部署场景。通过可视化建模与模块化设计,系统可实现多站点的快速搭建、跨平台协同管理及数据智能分析,满足政府、企业、教育机构等组织对多站点统一管控的
立即学习“Java免费学习笔记(深入)”;
这个题目的难点在于括号的处理上,有三种类型的括号,括号与括号之间有嵌套,有N对括号的情况。
//利用进出栈括号相抵,求对应括号的位置
function findBracket(str){
var stack = ["("];
for(var i=0;i 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= 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;
}










