给出一种物质的分子式(不带括号),求分子量。本题中的分子式只包含4中原子,分别为C,H,O,N,原子量分别为12.01,1.008,16.00,14.01(单位:g/mol)。例如,C6H5OH的分子量为94.108g/mol,该物质的分子量计算过程为
94.108=12.01\*6+1.008\*6+16.00\*1+14.01\*0。
#include <stdio.h>
#include <string.h>
#define maxn 105
int szpd(char a)
{
char x=a;
if(a>=48&&a<=57)
{
return 1;
}
else
{
return 0;
}
}
int main()
{
//freopen("3_20010.in","r",stdin);
//freopen("3_20010.out","w",stdout);
int i=0,len,countC=0,countH=0,countO=0,countN=0;
int sumC=0,sumH=0,sumO=0,sumN=0;
char s[maxn];
scanf("%s",s);
len=strlen(s);
while(i<len)//计算CHON各有多少个
{
if(s[i]=='C')
{
i++;
if(!szpd(s[i]))
{
countC++;
}
else
{
while(szpd(s[i]))
{
countC=countC*10+(s[i]-48);
//printf("*%d*\n",countC);
i++;
}
}
sumC+=countC;
countC=0;
}
if(s[i]=='H')
{
i++;
if(!szpd(s[i]))
{
countH++;
}
else
{
while(szpd(s[i]))
{
countH=countH*10+(s[i]-48);
i++;
}
}
sumH+=countH;
countH=0;
}
if(s[i]=='O')
{
i++;
if(!szpd(s[i]))
{
countO++;
}
else
{
while(szpd(s[i]))
{
countO=countO*10+(s[i]-48);
i++;
}
}
sumO+=countO;
countO=0;
}
if(s[i]=='N')
{
i++;
if(!szpd(s[i]))
{
countN++;
}
else
{
while(szpd(s[i]))
{
countN=countN*10+(s[i]-48);
i++;
}
}
sumN+=countN;
countN=0;
}
}
//printf("%d",sumC);
//printf("%d %d %d %d",sumC,sumH,sumO,sumN);
printf("%lf",sumC*12.01+sumH*1.008+sumO*16.00+sumN*14.01);
//fclose(stdin);
//fclose(stdout);
}