算法竞赛入门经典习题3-2

给出一种物质的分子式(不带括号),求分子量。本题中的分子式只包含4种原子,分别为C,H,O,N,分子量分别为12.01,1.008,16.00,14.01(单位:g/mol)。例如,C6H5OH的分子量为94.108g/mol。

这道题怎么说的乍一看简单的很,其实一看例子就知道了,如果字母后面没有数字呢?怎么判断,没有数字算作一个,在最后一个的话简单,如果是在中间出现这么一个字母,那么就要检测字母。

开干:

首先要知道数字的ACSII码,这样才能判断并且知道这个数到底是几。

当写到这里,你就一定知道了又一个陷阱,就是如果数字是两位数怎么办,三位数怎么办,还要一直判断下去么,怎么写才简单呢?

看了很多其他人的解法好多都是最多只判断到两位数那三位数四位数到底怎么办?

这么一道看似简单的题我却研究了好久好久,终于以位置为中心研究出来了。直接看代码吧

#include<stdio.h>
#include<string.h>
#include<ctype.h>
typedef struct Point{
    char a;//字母
    int b;//位置
}point;
double isch(char a){
    if(a=='C') return 12.01;
    else if(a=='H') return 1.008;
    else if(a=='O') return 16.00;
    else if(a=='N') return 14.01;
    else return 0;
}
int main(){
    char a[20];
    double number=0.0;
    int b[20],count=0;
    point p[10];
    memset(b,0,sizeof(b));
    scanf("%s",a);
    for(int i=0;i<strlen(a);i++){//记录每个字母出现的位置
        if(a[i]>=65&&a[i]<=90){
            p[count].a=a[i]; p[count].b=i;
            count++;
        }
    }    
    for(int i=0;i<count-1;i++){
        int x=p[i+1].b-p[i].b;
        if((p[i].b+1)==p[i+1].b){
            number=number+isch(p[i].a);
        }else{
            int y=1,z=0;
            for(int k=1;k<x-1;k++) y=y*10;
            for(int j=p[i].b+1;j<p[i].b+x;j++){
                z=z+y*(a[j]-'0'); y=y/10;
            }
            number=number+isch(p[i].a)*z;
        }
    }
    if((strlen(a)-1)==p[count-1].b){
        number=number+isch(p[count-1].a);
    }else{
        int x=strlen(a)-1-p[count-1].b;
        int y=1,z=0;
            for(int k=1;k<x-1;k++) y=y*10;
            for(int j=p[count-1].b+1;j<p[count-1].b+x;j++){
                z=z+y*(a[j]-'0'); y=y/10;
            }
            number=number+isch(p[count-1].a)*z;
    }
    printf("%.3fg/mol",number);
    return 0;
}
虽然看着有点多,但是可以说是解决了那个“简单”的问题。如有错误,请各位联系我。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值