天天看点

挑战密室

描述

R组织的特工Dr. Kong 为了寻找丢失的超体元素,不幸陷入WTO密室。Dr. Kong必须尽快找到解锁密码逃离,否则几分钟之后,WTO密室即将爆炸。

Dr. Kong发现密室的墙上写了许多化学方程式中。化学方程式,也称为化学反应方程式,是用化学式表示物质化学反应的式子。化学方程式反映的是客观事实。因此书写化学方程式要遵守两个原则:一是必须以客观事实为基础;二是要遵守质量守恒定律。

化学方程式不仅表明了反应物、生成物和反应条件。同时,化学计量数代表了各反应物、生成物物质的量关系,通过相对分子质量或相对原子质量还可以表示各物质之间的质量关系,即各物质之间的质量比。对于气体反应物、生成物,还可以直接通过化学计量数得出体积比。例如:2NaOH+H2SO4=Na2SO4+2H2O

经过多次试探、推理,Dr. Kong发现密码是4位数字,就隐藏在化学方程式等号后的第一个分子中,其分子量就可能是密码(若分子量不足4位,前面加0)。

好在Dr. Kong还记得墙上各化学方程式用到的化学元素的原子量如下:

N C O Cl S H Al Ca Zn Na
14 12 16 35 32 2 27 40 65 23

你能帮Dr. Kong尽快找到密码吗?

输入

第一行: K,表示有K个化学方程式;

接下来有K行,每行为一个化学方程式

输出

对于每个化学方程式输出一行:即密码。

样例输入

3
2C+O2=2CO
2NaOH+H2SO4=Na2SO4+2H2O
Ca2CO3+H2O=Ca2(OH)2+CO2
      

样例输出

0056
0142
0116
      

提示

2≤K≤8 ,化学方程式的长度不超过50, 所有原子,分子的数量不超过9.小括号最多一层.

来源

第八届河南省程序设计大赛

AC码:

#include<iostream>
#include<cstdio>
#include<cstring>
#include<iomanip> 

using namespace std;
int val[10]={14,12,16,35,32,2,27,40,65,23};
char che[10][3]={"N","C","O","Cl","S","H","Al","Ca","Zn","Na"};


int ln(char str[])
{
	for(int i=0;i<10;i++)
	{
		if(strcmp(str,che[i])==0)
		return val[i];//字母相等,返回字母所代表的能量值 
	}
}
int main()
{
	int k;
	scanf("%d",&k);
	char str[500];
	while(k--)
	{
		bool flag=false;//做判断用的(0) 
		int j=0;//记录下标 
		char b[55];//将=号后第一个分子存到b[]数组中 
		memset(str,0,sizeof(str));//初始0化 
		memset(b,0,sizeof(b));//初始0化 
		scanf("%s",str);//输入化学方程式
		for(int i=0;i<strlen(str);i++)
		{
			if(str[i]=='+'&&flag)
			break;//在=之后遇到+号时运行结束
			if(str[i]=='=')
			{//如果遇到=,结束本次循环 
				flag=true;
				continue;
			}
			if(flag)//将=号后第一个分子存到a[]数组中 
			b[j++]=str[i];
		}
		char ch[3];
		int sum=0,head=1,star=0,n;
		if(b[0]>='0'&&b[0]<='9')
		{
			head=b[0]-'0';
			star=1;
		}
		for(int i=star;i<j;i++)
		{
			memset(ch,0,sizeof(ch));
			n=1;//记录离子出现的次数
			if(b[i]=='(')
			{//如果括号在前
				i++;
				int temp=0;
				while(b[i]!=')'&&i<j)
				{
					memset(ch,0,sizeof(ch));
					if((b[i]>='A'&&b[i]<='Z')&&(b[i+1]>='a'&&b[i+1]<='z'))
					{
						if(b[i+2]>='0'&&b[i+2]<='9')
						n=b[i+2]-'0';//n表示化学元素有几个 
						ch[0]=b[i];
						ch[1]=b[i+1];
						ch[2]='\0';
						i++;
						temp+=n*ln(ch);//由两个元素组成的原子质量 
					}
					else if((b[i]>='A'&&b[i]<='Z')&&!(b[i+1]>='a'&&b[i+1]<='z'))
					{
						if(b[i+1]>='0'&&b[i+1]<='9')
						n=b[i+1]-'0';
						ch[0]=b[i];
						ch[1]='\0';
						temp+=n*ln(ch);//由一个元素组成的原子质量
					}
					i++;
				}
				if(b[i+1]>='0'&&b[i+1]<='9')
				n=b[i+1]-'0';//遇到离子有多个数
				sum+=n*temp;//乘与*个数 
			 } 
			 else if((b[i]>='A'&&b[i]<='Z')&&(b[i+1]>='a'&&b[i+1]<='z'))
					{
						if(b[i+2]>='0'&&b[i+2]<='9')
						n=b[i+2]-'0';
						ch[0]=b[i];
						ch[1]=b[i+1];
						ch[2]='\0';
						i++;
						sum+=n*ln(ch);//由两个元素组成的原子质量
					}
					else if((b[i]>='A'&&b[i]<='Z')&&!(b[i+1]>='a'&&b[i+1]<='z'))
					{
						if(b[i+1]>='0'&&b[i+1]<='9')
						n=b[i+1]-'0';
						ch[0]=b[i];
						ch[1]='\0';
						sum+=n*ln(ch);//由一个元素组成的原子质量
					}
		}
		sum*=head;
		cout<<setfill('0')<<setw(4)<<sum<<endl;//输出要求
		/* 留4位,如果不满四位,用0代替 */ 
	}
	return 0;
}
           
挑战密室