• <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>

            M.J的blog

            algorithm,ACM-ICPC
            隨筆 - 39, 文章 - 11, 評論 - 20, 引用 - 0
            數(shù)據(jù)加載中……

            TOJ 2219. A famous math puzzle

            是個關(guān)于拓展歐幾里得的問題,但是很難想到。這題也是看了結(jié)題報告的~~

            關(guān)于拓展歐幾里得的算法http://mj-zhang.blogbus.com/tag/拓展歐幾里得/

            大意是給N個瓶子,每個瓶子有個容量C,給定一個容量W,每次只能(1)灌滿一個,(2)倒空一個,(3)把一個的水倒給另一個,直到一個滿了或者一個空了。通過三種操作,有沒有可能最后達到某個瓶子里有W的水??梢赃@樣考慮:

            1)當(dāng)所有C都小于W,肯定不行;

            2)如果有N個瓶子,N個瓶子的容量C1, C2, C3 ... Cn必然有個最大公約數(shù)P。

            證明:假設(shè)n個水壺的容量分別為C1,C2,C3…..Cn.
            必要性:不管執(zhí)行三種操作的那一種,壺中所含的水一定是P的整數(shù)倍.
            充分性:由歐幾里德算法擴展可知,必然存在整數(shù)A1,A2,A3…..An,使得
             A1*C1+A2*C2+A3*C3+…+An*Cn=W.
                如果Ai是正數(shù),我們就用第i個壺從水源中取Ai次水;如果Ai為負(fù)數(shù),我們就把第i個壺倒空Ai次,這樣最后必會剩下W升水

          1.  1 #include<stdio.h>

             2 int gcd(int a,int b){

             3     int temp;

             4     if(a<b) {temp=b;b=a;a=temp;}

             5     if(a%b==0return b;

             6     else  return gcd(b,a%b);

             7 }
             8 int main()
             9 {
            10     int i,j,k,n,w,flag,tep,a[102];

            11     while(scanf("%d%d",&n,&w)!=EOF){

            12         if(n==0&&w==0break;

            13         flag=0;a[n+1]=0;

            14         for(i=1;i<=n;i++){

            15             scanf("%d",&a[i]);

            16             if(a[i]>=w) flag=1;

            17         }

            18         if(flag&&n!=1){

            19             tep=gcd(a[1],a[2]);

            20             for(i=3;i<=n;i++)

            21                 tep=gcd(tep,a[i]);

            22                 if(w%tep!=0)

            23                     flag=0;

            24         }

            25         if(n==1&&a[1]!=w) flag=0;

            26         else if(n==1&&a[1]==w) flag=1;

            27         if(flag) printf("YES\n");

            28         else  printf("NO\n");

            29     }
            30 
            31 }
          2. posted on 2010-04-23 19:41 M.J 閱讀(242) 評論(0)  編輯 收藏 引用


            只有注冊用戶登錄后才能發(fā)表評論。
            網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


            久久www免费人成精品香蕉| 中文国产成人精品久久亚洲精品AⅤ无码精品 | jizzjizz国产精品久久| 97久久婷婷五月综合色d啪蜜芽| 精品国产乱码久久久久软件| 蜜臀av性久久久久蜜臀aⅴ麻豆| 国产综合成人久久大片91| 午夜视频久久久久一区 | 国产精品99久久精品爆乳| 中文字幕无码久久精品青草 | 中文字幕成人精品久久不卡| 无码人妻久久一区二区三区蜜桃| 亚洲精品国产综合久久一线| 久久精品www人人爽人人| 亚洲国产美女精品久久久久∴ | 亚洲国产精品无码久久久蜜芽| 亚洲∧v久久久无码精品| 狠狠狠色丁香婷婷综合久久五月 | 18岁日韩内射颜射午夜久久成人| 久久久WWW免费人成精品| 99久久婷婷国产一区二区| 久久SE精品一区二区| 日韩人妻无码一区二区三区久久99| 三上悠亚久久精品| 一级女性全黄久久生活片免费 | 亚洲国产精品无码久久青草| 亚洲国产精品无码久久九九| 日韩亚洲国产综合久久久| 无码人妻久久久一区二区三区| 国产成人香蕉久久久久| 国产综合精品久久亚洲| 久久99久久99精品免视看动漫| 久久精品国产亚洲一区二区三区| 国产免费久久精品丫丫| 亚洲日本va午夜中文字幕久久 | 久久久久综合网久久| 一本色道久久88加勒比—综合| 7777久久久国产精品消防器材| 亚洲AV日韩精品久久久久久久| 久久久精品人妻一区二区三区四| 久久性生大片免费观看性|