算法学习之路|摩尔质量

给一串分子式,求它的相对分子质量
只含C,H,O,N
C=12.01 g/mol
H=1.008 g/mol
O=16.00 g/mol
N=14.01 g/mol
输入格式
第一行一个数n表示分子式数量,接下来n行每行一个分子式
输出格式
每行输出一个相对分子质量

输入样例:
4
C
C6H5OH
NH2CH2COOH
C12H22O11

输出样例:
12.010
94.108
75.070
342.296

主要需要注意如何正确识别字母之后的数字,并转化成数字存储

#include<stdio.h>
#include<string.h>
int main()
{
    char chem[100];
    double cal[200];
    memset(cal,0,sizeof(cal));
    double h=1.008,c=12.01,o=16.00,n=14.01,m=0;
    int x,i,j,t=0;
    scanf("%d",&x);
    for(i=0;i<x;i++)
    {
        scanf("%s",chem);
        for(j=1;j<=strlen(chem);j++)
        {
            if(chem[j-1]=='H')
                {cal[t]=h;
                 t++;
                 cal[t]=1;
                }
            else if(chem[j-1]=='C')
                {cal[t]=c;
                 t++;
                 cal[t]=1;
                }
            else if(chem[j-1]=='O')
                {cal[t]=o;
                 t++;
                 cal[t]=1;
                }
            else if(chem[j-1]=='N')
                {cal[t]=n;
                 t++;
                 cal[t]=1;
                }
            if(chem[j]<='9'&&chem[j]>='0'&&chem[j-1]>'A'&&chem[j-1]<'Z')
                {
                cal[t]=(double)(chem[j]-'0');
                }
            else if(chem[j]<='9'&&chem[j]>='0'&&chem[j-1]<='9'&&chem[j-1]>='0')
                {
                    t--;
                    cal[t]=cal[t]*10+(double)(chem[j]-'0');
                }
            if(chem[j+1]<='Z'&&chem[j+1]>='A'&&chem[j]<='9'&&chem[j]>='0')
                t--;
            t++;
        }
        for(j=0;j<t;j+=2)
        {
            m+=(cal[j]*cal[j+1]);
        }
        printf("%.3f\n",m);
        memset(cal,0,sizeof(cal));
        t=0;
        m=0;
    }
    return 0;
}
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值