UVa 1586 Molar mass(分子量)

描述bobo是一个从不讽刺人的品学兼优的好孩子,他最近沉迷学习化学而不能自拔。然而计算一个分子的相对分子质量使她烦不胜烦,因此她决定请你写一个程序来帮助她计算这种麻烦的事情。

已知:
①C代表的碳元素的相对原子质量为12.01,H代表的氢元素的相对原子质量为1.008,O代表的氧元素的相对原子质量为16.00,N代表的氮元素的相对原子质量为14.01。
②一个分子的相对分子质量等于组成这个分子的所有原子的相对原子质量的和:例如,分子式为C6H5OH的分子的相对分子质量为:12.01*6+1.008*5+16.00+1.008=94.108。输入输入首先是一个整数n,代表接下来有n个分子式。

接下来的n行,每行有一个字符串形式的分子式。数据保证字符串的长度不超过90。
在分子式中,只可能出现C、H、O、N四种字母。
在分子式中,每个代表元素的字母后面可能会出现数字,这些数字将不小于1且不大于100。
输出对于每组输入,在单独的一行内输出他的相对分子质量,小数点后保留3位(%.3lf)。样例输入
4
C
C6H5OH
NH2CH2COOH
C12H22O11
样例输出
12.010
94.108
75.070
342.296


解答:
#include<iostream>
#include<cstring>
#include<cstdio>
using namespace std;
char s='\n';
int read()
{
    s=getchar();
    if(s<'0'||s>'9') return 1;
    int x=0;
    while(s>='0'&&s<='9')
    {
        x=x*10+s-'0';
        s=getchar();
    }
    return x;
}
int main()
{
    double ans=0;
    int n;
    
    scanf("%d",&n);
    for(int i=1;i<=n;i++)
    {
        while(s=='\n') s=getchar();
        while(s=='C'||s=='H'||s=='O'||s=='N')
        {
            if(s=='C') ans+=12.01*read();
            if(s=='H') ans+=1.008*read();
            if(s=='O') ans+=16*read();
            if(s=='N') ans+=14.01*read();
        }
        printf("%.3lf\n",ans);
        ans=0;
    }    
    return 0;
}
上一篇:Uva_156 Ananagrams ( map 的应用 )


下一篇:UVa 1585 Score(得分)