• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            f(sixleaves) = sixleaves

            重劍無鋒 大巧不工

              C++博客 :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理 ::
              95 隨筆 :: 0 文章 :: 7 評論 :: 0 Trackbacks
             思路,其實還是切分單詞,只不過這里的單詞,變成了數字。代碼如下。

             1 #include <stdio.h>
             2 #include <string.h>
             3 #include <ctype.h>
             4 #define MAXN 100
             5 
             6 char buf[MAXN] = {0};
             7 double t[26] = {0};
             8 int readInt(char * buf, int i, int *num);
             9 int main() {
            10     
            11     int n;
            12     int ch, num;
            13     t['C'-'A'] = 12.01, t['H'-'A'] = 1.008;
            14     t['O' - 'A'] = 16.00, t['N' - 'A'] = 14.01;
            15     scanf("%d", &n);
            16     
            17     while (n > 0) {
            18         
            19         //  1.輸入數據
            20         scanf("%s", buf);
            21         int len = strlen(buf);
            22         double sum = 0.0;
            23         int i = 0;
            24         
            25         //  2.計算
            26         for (;;) {
            27             
            28             for (; buf[i]&&isalpha(buf[i]); i++) {
            29                 sum += t[buf[i] - 'A'];
            30             }
            31             if (i >= len) break;
            32             
            33             //  2.1[i, e)為整數范圍,num為整數值
            34             int e,num;
            35             e = readInt(buf, i, &num);
            36             sum += t[buf[i - 1] - 'A'] * (num - 1);
            37             i = e;
            38         }
            39         
            40         //  3.輸出結果
            41         printf("%.3f\n", sum);
            42         n--;
            43     }
            44     
            45     return 0;
            46 }
            47 
            48 //  如果沒有找到則返回i
            49 int readInt(char * buf, int i, int *num) {
            50     int sum = 0;
            51     int j;
            52     for (j = i; buf[j] && isdigit(buf[j]); j++) {
            53         sum *= 10;
            54         sum += buf[j] - '0';
            55     }
            56     *num = sum;
            57     return j;
            58     
            59 }
            by sixleaves
            posted on 2015-02-05 19:37 swp 閱讀(488) 評論(0)  編輯 收藏 引用 所屬分類: algorithm
            一级女性全黄久久生活片免费| 久久久国产精品福利免费| 国产精品一区二区久久精品| 久久久国产亚洲精品| 久久久久一本毛久久久| 免费一级欧美大片久久网| 亚洲国产成人久久综合碰| 日本久久久久久久久久| 无码国内精品久久综合88| 97久久国产综合精品女不卡| 亚洲伊人久久大香线蕉综合图片 | 亚洲αv久久久噜噜噜噜噜| 伊人久久大香线蕉成人| 国内精品伊人久久久影院| 国产成人久久精品一区二区三区 | 韩国三级中文字幕hd久久精品| 国内精品伊人久久久久av一坑| 亚洲午夜久久久久久噜噜噜| 97久久精品无码一区二区天美| 精品熟女少妇a∨免费久久| 国产一区二区三区久久| 久久精品国产色蜜蜜麻豆| 国内精品久久久久久久久电影网 | 91精品国产91热久久久久福利 | 精品久久久久久无码专区| 久久久久久亚洲Av无码精品专口| 新狼窝色AV性久久久久久| 国产一级持黄大片99久久| 中文成人无码精品久久久不卡 | 99久久婷婷免费国产综合精品| 一本久久知道综合久久| 老司机国内精品久久久久| 亚洲日韩欧美一区久久久久我| 香蕉99久久国产综合精品宅男自 | 日韩亚洲国产综合久久久| 久久亚洲精品中文字幕| 久久久久99精品成人片| 久久国产精品一国产精品金尊| 伊人丁香狠狠色综合久久| 国产成人精品综合久久久久 | 久久se精品一区精品二区国产|