题目:给出一种物质的分子式(不带括号),求分子量。本题中的分子式只包含4种原子,分别为C,H,O,N,原子量分别为12.01,1.008,16.00,14.01(单位:g/mol).例如,C6H5OH的分子量为94.108g/mol。
我看了其他几个回答,基本上都没有考虑C110...这种情况,题目中也没有叙述原子数小于10,于是我中间加了一段改良版的。
#include <stdio.h>
#include<string.h>
#include<ctype.h>
#define maxn 102
double tran(char x)
{
if(x=='C')return 12.01;
if(x=='H')return 1.008;
if(x=='O')return 16.00;
if(x=='N')return 14.01;
}
char s[maxn];
int main()
{
scanf("%s",s);
int len=strlen(s);
int i;
char item;
int times=1;
double result;
for(i=0;i<len-1;i++)
{
if(isdigit(s[i])) continue;
if(isalpha(s[i])&&isdigit(s[i+1]))
{
item=s[i];
times=s[i+1]-'0';
//这是判断后面的数字有几位而添加上去的内容。
int j;
for(j=i+2;j<len;j++)
{
if(isalpha(s[j]))
{
printf("GG\n");
break;
}
else if(isdigit(s[j]))
{
printf("gg\n");
times=times*10+s[j]-'0';
}
}
}
else if(isalpha(s[i])&&!isdigit(s[i+1]))
{
item=s[i];
times=1;
}
result+=tran(item)*times;
printf("item=%lf times=%d result=%lf\n",tran(item),times,result);
}
if(isalpha(s[len-1]))
{
result+=tran(s[len-1]);
}
printf("%lf\n",result);
return 0;
}