GDUFE ACM-1356

本文介绍了一种计算由氢、氧、碳三种原子组成的分子相对原子质量的方法,并提供了一个简单的C语言实现方案。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

题目:http://acm.gdufe.edu.cn/Problem/read/id/1356

 

Problem B. Relative atomic mass

Time Limit: 2000/1000ms (Java/Others)

Problem Description:

Relative atomic mass is a dimensionless physical quantity, the ratio of the average mass of atoms of an element (from a single given sample or source) to 1/12 of the mass of an atom of carbon-12 (known as the unified atomic mass unit). You need to calculate the relative atomic mass of a molecule, which consists of one or several atoms. In this problem, you only need to process molecules which contain hydrogen atoms, oxygen atoms, and carbon atoms. These three types of atom are written as ’H’, ’O’ and ’C’ repectively. For your information, the relative atomic mass of one hydrogen atom is 1, and the relative atomic mass of one oxygen atom is 16 and the relative atomic mass of one carbon atom is 12. A molecule is demonstrated as a string, of which each letter is for an atom. For example, a molecule ’HOH’ contains two hydrogen atoms and one oxygen atom, therefore its relative atomic mass is 18 = 2∗1 + 16. 

Input:

The first line of input contains one integer N(N ≤ 10), the number of molecules. In the next N lines, the i-th line contains a string, describing the i-th molecule. The length of each string would not exceed 10. 

Output:

For each molecule, output its relative atomic mass. 

Sample Input:

5
H
C
O
HOH
CHHHCHHOH

Sample Output:

1
12
16
18
46

思路:判断遇到的字符是哪一个,如果遇到'H'则+1,如果遇到'C'则+12,如果遇到'O'则+16

难度:非常简单

代码:
 1 #include<stdio.h>
 2 #include<string.h>
 3 int main()
 4 {
 5     int n,i,sum,k;
 6     char a[11];
 7     while(scanf("%d",&n)!=EOF)
 8     {
 9         while(n--)
10         {
11             sum=0;
12             scanf("%s",&a);
13             k=strlen(a);
14             for(i=0;i<k;i++)
15             {
16                 if(a[i]=='H')
17                     sum+=1;
18                 else if(a[i]=='O')
19                     sum+=16;
20                 else if(a[i]=='C')
21                     sum+=12;
22             }
23             printf("%d\n",sum);
24         }
25     }
26     return 0;
27 }

 

转载于:https://www.cnblogs.com/ruo786828164/p/6009316.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值