黄色网页视频 I 影音先锋日日狠狠久久 I 秋霞午夜毛片 I 秋霞一二三区 I 国产成人片无码视频 I 国产 精品 自在自线 I av免费观看网站 I 日本精品久久久久中文字幕5 I 91看视频 I 看全色黄大色黄女片18 I 精品不卡一区 I 亚洲最新精品 I 欧美 激情 在线 I 人妻少妇精品久久 I 国产99视频精品免费专区 I 欧美影院 I 欧美精品在欧美一区二区少妇 I av大片网站 I 国产精品黄色片 I 888久久 I 狠狠干最新 I 看看黄色一级片 I 黄色精品久久 I 三级av在线 I 69色综合 I 国产日韩欧美91 I 亚洲精品偷拍 I 激情小说亚洲图片 I 久久国产视频精品 I 国产综合精品一区二区三区 I 色婷婷国产 I 最新成人av在线 I 国产私拍精品 I 日韩成人影音 I 日日夜夜天天综合

1025:統(tǒng)計(jì)硬幣

系統(tǒng) 2134 0

題目描述

假設(shè)一堆由1分、2分、5分組成的n個(gè)硬幣總面值為m分,求一共有多少種可能的組合方式(某種面值的硬幣可以數(shù)量可以為0)。

輸入格式

輸入數(shù)據(jù)第一行有一個(gè)正整數(shù)T,表示有T組測試數(shù)據(jù)。接下來的T行,每行有兩個(gè)數(shù)n,m,n和m的含義同上。

輸出

對于每組測試數(shù)據(jù),請輸出可能的組合方式數(shù),每組輸出占一行。

樣例輸入

2
3?5
4?8

樣例輸出

1
2

本題的思路類似于雞兔同籠問題,所以不難想到使用幾個(gè)for循環(huán)對可能值進(jìn)行窮舉,下面是我寫的一個(gè)算法,在窮舉上略有優(yōu)化。

      
         1
      
       #include <stdio.h>


      
         2
      
      
        int
      
       main(
      
        void
      
      
        )


      
      
         3
      
      
        {


      
      
         4
      
      
        int
      
      
         n,m;


      
      
         5
      
      
        int
      
      
         time;


      
      
         6
      
      
         7
      
           scanf(
      
        "
      
      
        %d
      
      
        "
      
      ,&
      
        time);


      
      
         8
      
      
        while
      
      (time--
      
        )


      
      
         9
      
      
            {    


      
      
        10
      
      
        11
      
      
        int
      
       count=
      
        0
      
      
        ;


      
      
        12
      
               scanf(
      
        "
      
      
        %d %d
      
      
        "
      
      ,&n,&
      
        m);


      
      
        13
      
      
        int
      
      
         i,j,k,total;


      
      
        14
      
      
        15
      
      
        for
      
      (i=
      
        0
      
      ;i<=(m/
      
        5
      
      );i++
      
        )


      
      
        16
      
      
                {


      
      
        17
      
      
        18
      
      
        for
      
      (j=
      
        0
      
      ;j<=(m/
      
        2
      
      );j++
      
        )


      
      
        19
      
      
                        {


      
      
        20
      
                           k=n-j-
      
        i;                


      
      
        21
      
                           total=k*
      
        1
      
      +j*
      
        2
      
      +i*
      
        5
      
      
        ;


      
      
        22
      
      
        if
      
      (total==
      
        m)


      
      
        23
      
                                   count++
      
        ;


      
      
        24
      
      
                        }


      
      
        25
      
      
        26
      
      
                }


      
      
        27
      
               printf(
      
        "
      
      
        %d\n
      
      
        "
      
      
        ,count);


      
      
        28
      
      
            }


      
      
        29
      
      
        return
      
      
        0
      
      
        ;


      
      
        30
      
       }
    

提交后仍有錯(cuò)誤,暫未發(fā)現(xiàn)在何處。下面是官方的算法,較之又有一些優(yōu)化。

      
         1
      
       #include<stdio.h>


      
         2
      
      
         3
      
      
        int
      
      
         main()


      
      
         4
      
      
        {


      
      
         5
      
      
        int
      
      
         t,n,m,c1,c2,c5,k;


      
      
         6
      
               scanf(
      
        "
      
      
        %d
      
      
        "
      
      ,&
      
        t);


      
      
         7
      
      
        while
      
      (t--
      
        )


      
      
         8
      
      
                {


      
      
         9
      
                       scanf(
      
        "
      
      
        %d%d
      
      
        "
      
      ,&n,&
      
        m);


      
      
        10
      
                       k=
      
        0
      
      
        ;


      
      
        11
      
      
        for
      
      (c5=
      
        0
      
      ;
      
        5
      
      *c5<=m;c5++
      
        )


      
      
        12
      
      
        for
      
      (c2=
      
        0
      
      ;
      
        2
      
      *c2+
      
        5
      
      *c5<=m;c2++
      
        )


      
      
        13
      
      
                                {


      
      
        14
      
                                       c1=m-
      
        5
      
      *c5-
      
        2
      
      *
      
        c2;


      
      
        15
      
      
        if
      
      (c1+c2+c5==
      
        n)


      
      
        16
      
                                               k++
      
        ;


      
      
        17
      
      
                                }


      
      
        18
      
                       printf(
      
        "
      
      
        %d\n
      
      
        "
      
      
        ,k);


      
      
        19
      
      
                }


      
      
        20
      
      
        return
      
      
        0
      
      
        ;


      
      
        21
      
       }
    

另外值得一提的是,本題與 1023——坑爹的黑店 在算法上有異曲同工之妙。

另:之后又根據(jù)官方修改,仍是不過。奇怪。

      
         1
      
       #include <stdio.h>


      
         2
      
      
        int
      
       main(
      
        void
      
      
        )


      
      
         3
      
      
        {


      
      
         4
      
      
        int
      
      
         n,m;


      
      
         5
      
      
        int
      
      
         time;


      
      
         6
      
      
         7
      
           scanf(
      
        "
      
      
        %d
      
      
        "
      
      ,&
      
        time);


      
      
         8
      
      
        while
      
      (time--
      
        )


      
      
         9
      
      
            {    


      
      
        10
      
      
        11
      
      
        int
      
       count=
      
        0
      
      
        ;


      
      
        12
      
               scanf(
      
        "
      
      
        %d %d
      
      
        "
      
      ,&n,&
      
        m);


      
      
        13
      
      
        int
      
      
         i,j,k,total;


      
      
        14
      
      
        15
      
      
        for
      
      (i=
      
        0
      
      ;
      
        5
      
      *i<=m;i++
      
        )


      
      
        16
      
      
                {


      
      
        17
      
      
        18
      
      
        for
      
      (j=
      
        0
      
      ;
      
        2
      
      *j<=m;j++
      
        )


      
      
        19
      
      
                        {


      
      
        20
      
                           k=n-j-
      
        i;                


      
      
        21
      
                           total=k*
      
        1
      
      +j*
      
        2
      
      +i*
      
        5
      
      
        ;


      
      
        22
      
      
        if
      
      (total==
      
        m)


      
      
        23
      
                                   count++
      
        ;


      
      
        24
      
      
                        }


      
      
        25
      
      
        26
      
      
                }


      
      
        27
      
               printf(
      
        "
      
      
        %d\n
      
      
        "
      
      
        ,count);


      
      
        28
      
      
            }


      
      
        29
      
      
        return
      
      
        0
      
      
        ;


      
      
        30
      
       }
    

?最后終于發(fā)現(xiàn)問題,關(guān)于k=n-i-j;因?yàn)閷τ趇,j的初始沒有限制,所以k可能是負(fù)值的情況沒有排除。

下面代碼AC

      
         1
      
       #include <stdio.h>


      
         2
      
      
        int
      
       main(
      
        void
      
      
        )


      
      
         3
      
      
        {


      
      
         4
      
      
        int
      
      
         n,m;


      
      
         5
      
      
        int
      
      
         time;


      
      
         6
      
      
         7
      
           scanf(
      
        "
      
      
        %d
      
      
        "
      
      ,&
      
        time);


      
      
         8
      
      
        while
      
      (time--
      
        )


      
      
         9
      
      
            {    


      
      
        10
      
      
        11
      
      
        int
      
       count=
      
        0
      
      
        ;


      
      
        12
      
               scanf(
      
        "
      
      
        %d %d
      
      
        "
      
      ,&n,&
      
        m);


      
      
        13
      
      
        int
      
      
         i,j,k,total;


      
      
        14
      
      
        15
      
      
        for
      
      (i=
      
        0
      
      ;
      
        5
      
      *i<=m;i++
      
        )


      
      
        16
      
      
                {


      
      
        17
      
      
        18
      
      
        for
      
      (j=
      
        0
      
      ;
      
        2
      
      *j<=m;j++
      
        )


      
      
        19
      
      
                        {


      
      
        20
      
                           k=n-j-
      
        i;                


      
      
        21
      
                           total=k*
      
        1
      
      +j*
      
        2
      
      +i*
      
        5
      
      
        ;


      
      
        22
      
      
        if
      
      (total==m&&k>=
      
        0
      
      
        )


      
      
        23
      
      
                            {


      
      
        24
      
      
        25
      
                               count++
      
        ;


      
      
        26
      
      
                            }


      
      
        27
      
      
        28
      
      
                        }


      
      
        29
      
      
        30
      
      
                }


      
      
        31
      
               printf(
      
        "
      
      
        %d\n
      
      
        "
      
      
        ,count);


      
      
        32
      
      
            }


      
      
        33
      
      
        return
      
      
        0
      
      
        ;


      
      
        34
      
       }
    

?

1025:統(tǒng)計(jì)硬幣


更多文章、技術(shù)交流、商務(wù)合作、聯(lián)系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號聯(lián)系: 360901061

您的支持是博主寫作最大的動(dòng)力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點(diǎn)擊下面給點(diǎn)支持吧,站長非常感激您!手機(jī)微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點(diǎn)擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對您有幫助就好】

您的支持是博主寫作最大的動(dòng)力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長會(huì)非常 感謝您的哦!!!

發(fā)表我的評論
最新評論 總共0條評論