欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

UVA1586 分子量 Molar mass

程序员文章站 2024-03-19 19:13:26
...

题目描述

PDF
UVA1586 分子量 Molar mass

输入格式

输出格式

题意翻译

现给你若干个分子式需要你求分子量。

例如:C6H5OH的分子量为12.016+1.0085+16.00+1.008=94.108g/mol。

(ps:数字为数字前面元素的下标,所有分子式均无括号例如:2OH=2*16.00+1.008)

输入输出格式

输入:

输入n(2<=n<=99)

接下来n行为分子式

输出:

输出每个分子的分子式

输入输出样例

代码如下:

#include<stdio.h>
#include<stdlib.h>
#include<string.h>
#include<iostream>
#include<cstdio>
#include <algorithm>
#include<map>
using namespace std;
#pragma warning(disable:4996)
#pragma warning(disable:6031)

map<char,double>value;

int main()
{
	//通过map建立一对一映射
	value['C'] = 12.01, value['H']=1.008,value['O']=16.00,value['N']=14.01;
	int n;
	cin >> n;//次数
	while (n--)
	{
		string s;
		cin >> s;
		double ans = 0;
		int slen=s.length();//长度
		int j=0;
		for (int i=0;i<slen;i++)//循环判断
		{
			if (isalpha(s[i]))
			{
				ans += value[s[i]];//加上对应值
				j = i;
			}
			else
			{
				int temp=0;
				if (isdigit(s[i]))//遇到的第一个数字
				{
					temp = s[i] - '0';
					if (isdigit(s[i+1]))//其后跟随一个数字
					{
						temp = temp * 10 + s[i + 1] - '0';
						i++;
						
					}
					/*int y = 1;
					while ((i+y)<slen&&isdigit(s[i+y]))
					{
						temp = temp * 10 + s[i + 1] - '0';
						i++;
						y++;

					}*/

				}
				ans += value[s[j]] * (temp - 1);
			}
		}
		printf("%.3lf\n",ans);
		ans = 0;
	}
	return 0;
}
相关标签: ACM 算法 c++

上一篇: 509. 斐波那契数

下一篇: