给出一种物质的分子式(不带括号),求其分子量。本题分子式中只包含四种原子,分别为C、H、O、N,原子量分别为12.01,1.008,16.00,14.01。例如,C6H5OH的分子量为94.108g/mol。
此题为算法竞赛入门经典习题3-2,此题的难点在于如何分离输入中的数字与字符,更细致一点,数字可能是一位,两位,甚至三位。我的思路为循环判断当前位以及下一位,若当前位为字符,直接switch得到分子量,如果下一位为数字,则进入循环,获得数字,在看下一位,类似递归的思想吧,已经AC代码如下:
#include <stdio.h>
#include<string.h>
int main ()
{
int T;scanf("%d",&T);
while(T--){
char temc; // 元素
int temi=1; // 元素对应的个数
double sum=0; //分子总数
double temM=0; //分子量
int i=0;
char s[100];scanf("%s",s);
temc = s[0];
while(temc!='\0')
{
temi = 1;
switch(temc)
{
case 'C':temM=12.01;break;
case 'H':temM = 1.008;break;
case 'O':temM = 16.00;break;
case 'N':temM = 14.01;break;
}
if(s[i+1]<='9'&&s[i+1]>='0') //是数字
{
i++;
temi = s[i]-'0';
while(s[i+1]>='0'&&s[i+1]<='9') //计算总分子量
{
temi*=10;
temi+=(s[i+1]-'0');
i++;
}
}
sum += temi*temM;
temc = s[++i];
}
printf("%.3f\n",sum);
}
return 0;
}