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

            Sephiroth's boring days!!!

            Love just for you.

            數(shù)學(xué)問(wèn)題-Black and White

            【題目描述】

            尋找一個(gè)由n個(gè)整數(shù)組成的數(shù)列,其中任意連續(xù)p個(gè)整數(shù)之和為正,任意連續(xù)q個(gè)整數(shù)之和為負(fù)。若不存在這樣的整數(shù)數(shù)列,則輸出NO,否則輸出其中一個(gè)數(shù)列。

            【輸入】

            對(duì)于每個(gè)測(cè)試點(diǎn)將給你M組數(shù)據(jù),要求你對(duì)于每組數(shù)據(jù),判斷是否存在這樣的整數(shù)數(shù)列。

            輸入的第一行是一個(gè)正整數(shù)M,(1<=N<=10000),接下來(lái)的M行對(duì)應(yīng)M組數(shù)據(jù),每行有三個(gè)正整數(shù)N、P、Q(1<=n,p,q<=10^8)。

            【輸出】

            輸出數(shù)據(jù)共N行,每行為yes或者no,如果第I組數(shù)據(jù)有解,則在第I行輸出yes,否則輸出no

            【輸入輸出示例】

            輸入(sequence.in) 輸出(sequence.out)
            2
            1 1 9
            10 2 4
            yes
            no

            【評(píng)分標(biāo)準(zhǔn)】

            對(duì)于每個(gè)測(cè)試點(diǎn),如果你能夠在1S內(nèi)通過(guò)每組數(shù)據(jù),你將得到這個(gè)測(cè)試點(diǎn)的分?jǐn)?shù),否則,這個(gè)測(cè)試點(diǎn)你只能得0分。

            【分析】

            原題目是要求輸出一種可能的解,如果沒(méi)有解就輸出-1。這樣的話(huà)就要用到差分約束。

            現(xiàn)在的話(huà),只需要一個(gè)公式。如果有解,應(yīng)滿(mǎn)足:n<=q+p-gcd(p,q)-1。

              1: #include <stdio.h>
            
              2: #include <iostream>
            
              3: using namespace std;
            
              4: 
            
              5: int n,m,p,q;
            
              6: 
            
              7: int gcd(int a,int b)
            
              8: {
            
              9:     if (a<b) swap(a,b);
            
             10:     int t;
            
             11:     while (b!=0)
            
             12:     {
            
             13:         t=a;
            
             14:         a=b;
            
             15:         b=t%a;
            
             16:     }
            
             17:     return a;
            
             18: }
            
             19: 
            
             20: int main()
            
             21: {
            
             22:     freopen("sequence.in","r",stdin);
            
             23:     freopen("sequence.out","w",stdout);
            
             24:     
            
             25:     scanf("%d",&m);
            
             26:     for (int i=0;i<m;++i)
            
             27:     {
            
             28:         scanf("%d%d%d",&n,&p,&q);
            
             29:         if (n<=p+q+gcd(p,q)-1) printf("YES\n");
            
             30:         else printf("NO\n");
            
             31:     }
            
             32:     return 0;
            
             33: }
            
             34: 

            下面是我寫(xiě)的查分約束。

              1: #include <stdio.h>
            
              2: #define MAXINT 1000000
            
              3: #define maxn 1010
            
              4: 
            
              5: struct ss
            
              6: {
            
              7:     int x,y,dis;
            
              8: } l[10000];
            
              9: 
            
             10: int s[maxn];
            
             11: int a[maxn];
            
             12: int d[maxn];
            
             13: int n,q,p,tot;
            
             14: 
            
             15: int main()
            
             16: {
            
             17:     scanf("%d%d%d",&n,&p,&q);
            
             18:     for (int i=0;i<=n;++i)
            
             19:         if (i+p>n) break;
            
             20:         else
            
             21:         {
            
             22:             l[++tot].x=i+p;
            
             23:             l[tot].y=i;
            
             24:             l[tot].dis=-1;
            
             25:         }
            
             26:     for (int i=0;i<=n;++i)
            
             27:         if (i+q>n) break;
            
             28:         else
            
             29:         {
            
             30:             l[++tot].x=i;
            
             31:             l[tot].y=i+q;
            
             32:             l[tot].dis=-1;
            
             33:         }
            
             34:     for (int i=1;i<=n;++i)
            
             35:     {
            
             36:         for (int j=1;j<=tot;++j)
            
             37:             if (d[l[j].y]>d[l[j].x]+l[j].dis)
            
             38:                 d[l[j].y]=d[l[j].x]+l[j].dis;
            
             39:         for (int j=1;j<=tot;++j)
            
             40:             if (d[l[j].y]>d[l[j].x]+l[j].dis)
            
             41:             {
            
             42:                 printf("-1\n");
            
             43:                 return 0;
            
             44:             }
            
             45:     }
            
             46:     for (int i=0;i<=n;++i)
            
             47:         s[i]=d[i];
            
             48:     for (int i=1;i<=n;++i) printf("%d\n",s[i]-s[i-1]);
            
             49:     return 0;
            
             50: }
            
             51: 

            posted on 2010-09-01 07:00 Sephiroth Lee 閱讀(150) 評(píng)論(0)  編輯 收藏 引用 所屬分類(lèi): 信息奧賽

            free counters
            久久乐国产精品亚洲综合| 99久久夜色精品国产网站| 欧美精品福利视频一区二区三区久久久精品 | 久久WWW免费人成—看片| 免费观看成人久久网免费观看| 91精品国产9l久久久久| 久久se精品一区二区| 欧美午夜精品久久久久久浪潮| 久久亚洲sm情趣捆绑调教| 久久婷婷五月综合色奶水99啪| 久久久国产精品福利免费| 一本久久精品一区二区| 久久中文骚妇内射| 久久久久九九精品影院| 欧美大香线蕉线伊人久久| 久久91精品综合国产首页| 奇米综合四色77777久久| 国产日韩久久免费影院| 久久国产欧美日韩精品免费| 韩国无遮挡三级久久| 久久久无码精品亚洲日韩京东传媒 | 久久久久国产精品| 日韩十八禁一区二区久久| 久久无码人妻一区二区三区午夜| 欧美亚洲另类久久综合婷婷 | 亚洲中文字幕伊人久久无码| 国产午夜免费高清久久影院| 久久这里只精品99re66| 激情久久久久久久久久| 99久久99这里只有免费的精品| 伊人久久国产免费观看视频 | 狠狠色丁香久久婷婷综合| 国内精品久久久久久麻豆 | 久久99国产精一区二区三区| 久久综合九色综合网站| 人人狠狠综合久久亚洲高清| 狠狠色伊人久久精品综合网| 66精品综合久久久久久久| 国产精品女同久久久久电影院| 亚洲欧美伊人久久综合一区二区 | 亚洲国产精品久久电影欧美|