26行代码AC——习题3-2 分子量 (UVa1586,Molar Mass)——解题报告
生活随笔
收集整理的這篇文章主要介紹了
26行代码AC——习题3-2 分子量 (UVa1586,Molar Mass)——解题报告
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
大意:
給出分子式,式中只包含以下四種元素。求分子量。
C:12.01 H: 1.008 O: 16.00 N: 14.01
Sample Input
4
C
C6H5OH
NH2CH2COOH
C12H22O11
Sample Output
12.010
94.108
75.070
342.296
分析:
此題本質是利用#include<cctype>中isalpha()函數判斷是否為字母和isdigit()函數判斷是否為數字。
這種水題千萬不要想得太復雜,用最簡單的知識就可以AC。復雜的語法反到易錯而臃腫。
儲備知識:
1、有關頭文件#include<cctype>的知識擴展→cctype頭文件函數詳解
提交鏈接→UVa-1586
代碼:
#include <bits/stdc++.h> //萬能頭文件 using namespace std ; char c1[4] = {'C','H','O','N'} ; //常量數組,c1對應d1 float d1[4] = {12.01,1.008,16.00,14.01} ; int main() {int n; cin >> n; while(n--) {char a[85]; cin >> a; //存放化學式的數組 int len = strlen(a) ; //求化學式長度,于遍歷時使用。float sum = 0 ; //存放結果。 for(int i = (len-1); i >= 0; i--) { //逆序遍歷,優點在于識別數字。 float num = 1.0 ;if(isdigit(a[i])) { //如果是數字 num = (a[i]-'0'); i--; //num更新成該數字,向前挪一位 if(isdigit(a[i])) { num += ((a[i]-'0')*10); i--; } //如果上一位還是數字,該數*10加num。(相當于十位數) ,向前挪一位 } if(isalpha(a[i])) { //判斷是否是字母 int k = 0 ; for(k = 0 ;k < 4; k++) if(a[i] == c1[k]) { sum += (num*d1[k]); break; }} } printf("%.3f\n",sum) ;}return 0 ;}擇苦而安,擇做而樂。虛擬現實終究比不過真實精彩之萬一。
總結
以上是生活随笔為你收集整理的26行代码AC——习题3-2 分子量 (UVa1586,Molar Mass)——解题报告的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 如何获得所有CSDN勋章的获取方式?
- 下一篇: 神奇的sstream头文件(整型与字符串