分子量

题目

给出一种物质的分子式(不带括号),求分子量。本题中的分子式只包含4中原子,

分别为C,H,O,N,分子量分别为12.01,1.008,16.00,14.01(单位:g/mol)。

例如,C6H5OH的分子量为94.108g/mol。

 

分析

c*6+h*5+o+h = 94.108

判断当前位为字符,同时下一位是字符或者数字;

如果是字符,则加上当前位的原子量;

如果是数字,则当前位的原子量乘以该数字;

 

c实现

复制代码
#include<stdio.h>
#include<string.h>
#define maxn 101
char a[maxn];
const char* b="CHON";

int main()
{
    double sum=0.0;
    double c;
    scanf("%s",a);
    for(int i=0;i<strlen(a);i++)
    {
        int j=i;
        c=1.0;
        if(i+1<strlen(a) && strchr(b,a[i+1])==NULL){
            c=(a[i+1]-'1'+1)*1.0;
            i++;
        }
        switch(a[j])
        {
            case 'C':
                sum += 12.01 * c;
                break;
            case 'H':
                sum += 1.008 * c;
                break;
            case 'O':
                sum += 16.00 * c;
                break;
            case 'N':
                sum += 14.01 * c;
                break;
        }
    }
    printf("%.3f",sum);
    return 0;
}
复制代码

 

posted @   Vincent-yuan  阅读(2128)  评论(0编辑  收藏  举报
编辑推荐:
· AI与.NET技术实操系列:基于图像分类模型对图像进行分类
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
阅读排行:
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· 25岁的心里话
· ollama系列01:轻松3步本地部署deepseek,普通电脑可用
· 按钮权限的设计及实现
历史上的今天:
2019-05-23 java之struts2的数据处理
点击右上角即可分享
微信分享提示