刘汝佳的新题,可以一步一步处理,不过太麻烦,用sscanf函数直接一步处理就行了,注意字母后面没数字的时候默认为1。
#include<cstdio>
#include<cstring>
#include<iostream>
using namespace std;
#define MAXD 1000 + 10
const double M[] = {12.01,1.008,16.00,14.01};
int main(){
int T;
scanf("%d",&T);
while(T--){
char str[MAXD];
double ans = 0;
scanf("%s",str);
int L = strlen(str);
for(int i = 0 ; i < L ; i++){
if(str[i] == 'C'){
int m = 1;
sscanf(str + i + 1,"%d",&m);
ans += m * M[0];
}
else if(str[i] == 'H'){
int m = 1;
sscanf(str + i + 1,"%d",&m);
ans += m * M[1];
}
else if(str[i] == 'O'){
int m = 1;
sscanf(str + i + 1,"%d",&m);
ans += m * M[2];
}
else if(str[i] == 'N'){
int m = 1;
sscanf(str + i + 1,"%d",&m);
ans += m * M[3];
}
}
printf("%.3f\n",ans);
}
return 0;
}
本文介绍了一种使用C++实现的高效算法,该算法能够快速解析化学分子式并计算分子的摩尔质量。通过利用sscanf函数,算法能准确读取分子式中各元素及其数量,并基于预定义的原子质量数组计算总质量。
3620

被折叠的 条评论
为什么被折叠?



