首頁  >  文章  >  web前端  >  關於JavaScript解析化學分子式的程式碼實例分享

關於JavaScript解析化學分子式的程式碼實例分享

黄舟
黄舟原創
2017-03-18 14:55:153881瀏覽

給定一個化學分子式的字串,統計每一種元素原子的數量。

例如:

水分子'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解析化學分子式的程式碼實例分享的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn