• <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>
            心如止水
            Je n'ai pas le temps
            posts - 400,comments - 130,trackbacks - 0
            此題使用動態(tài)規(guī)劃。首先做一些預(yù)處理:排序。按體重由小到大排序,相同體重的按IQ遞減排序。動態(tài)規(guī)劃的狀態(tài)轉(zhuǎn)移方程為d[i]=max{d[j]+1|j<i,a[j].weight<a[i].weight,a[j].iq>a[i].iq}。
            以下是我的代碼:
            #include<stdio.h>

            //#define LOCAL

            typedef 
            struct
            {
                
            long id,weight,iq;
            }type;
            const long maxn=1007;
            long n,ans,pos,d[maxn],f[maxn],tmp[maxn];
            type a[maxn];
            void Qsort(long begin,long end)
            {
                
            long i=begin,j=end,mid1=a[(begin+end)/2].weight,mid2=a[(begin+end)/2].iq;
                type t;
                
            do{
                     
            while(a[i].weight<mid1||(a[i].weight==mid1&&a[i].iq>mid2)) i++;
                     
            while(a[j].weight>mid1||(a[j].weight==mid1&&a[j].iq<mid2)) j--;
                     
            if(i<=j)
                     {
                        t
            =a[i];a[i]=a[j];a[j]=t;
                        i
            ++;j--;
                     }
                }
            while(i<=j);
                
            if(i<end)   Qsort(i,end);
                
            if(j>begin) Qsort(begin,j);
            }
            int main()
            {
                #ifdef LOCAL
                freopen(
            "data.in","r",stdin);
                freopen(
            "data.out","w",stdout);
                
            #endif
                n
            =0;
                
            while(scanf("%ld%ld",&a[n+1].weight,&a[n+1].iq)==2)
                {
                   n
            ++;
                   a[n].id
            =n;
                }
                
            //  Input
                Qsort(1,n);
                
            //  Qsort
                for(long i=1;i<=n;i++)
                {
                   d[i]
            =1;
                   f[i]
            =0;
                }
                
            //  Init
                for(long i=1;i<=n;i++)
                  
            for(long j=1;j<i;j++)
                    
            if(a[i].weight>a[j].weight&&a[i].iq<a[j].iq&&d[i]<d[j]+1)
                    {
                       d[i]
            =d[j]+1;
                       f[i]
            =j;
                    }
                
            //  DP
                ans=0;pos=0;
                
            for(long i=1;i<=n;i++)
                  
            if(d[i]>ans)
                  {
                     ans
            =d[i];
                     pos
            =i;
                  }
                tmp[
            1]=a[pos].id;
                
            for(long i=2;i<=ans;i++,pos=f[pos])
                  tmp[i]
            =a[f[pos]].id;
                printf(
            "%ld\n",ans);
                
            for(long i=ans;i>=1;i--)
                  printf(
            "%ld\n",tmp[i]);
                
            //  Output
            return 0;
            }


            posted on 2010-02-08 14:19 lee1r 閱讀(710) 評論(0)  編輯 收藏 引用 所屬分類: 題目分類:動態(tài)規(guī)劃
            亚洲中文字幕伊人久久无码| 久久精品一区二区三区AV| 亚洲国产成人精品91久久久 | 日日狠狠久久偷偷色综合96蜜桃| 香蕉久久av一区二区三区| 久久青青草原亚洲av无码| 精品久久一区二区| 久久久91精品国产一区二区三区| 久久久久久久精品妇女99| 日本五月天婷久久网站| 人妻中文久久久久| 欧美大战日韩91综合一区婷婷久久青草| 久久精品九九亚洲精品天堂| 国产精品久久影院| 久久福利青草精品资源站| 久久久久亚洲AV成人片| 久久香蕉国产线看观看精品yw| 亚洲va久久久噜噜噜久久男同| 久久精品亚洲AV久久久无码| 国产成年无码久久久免费| 精品国产99久久久久久麻豆| 欧美午夜精品久久久久免费视| 午夜不卡久久精品无码免费| 狠狠色婷婷久久一区二区三区| 久久久久免费精品国产| 国产精品成人无码久久久久久| 99国产精品久久久久久久成人热| 久久精品国产影库免费看| 国内精品久久久久久不卡影院| 久久乐国产精品亚洲综合| 亚洲国产日韩综合久久精品| 国产精品国色综合久久| 狠狠色伊人久久精品综合网| 亚洲欧洲精品成人久久曰影片| 伊人久久大香线蕉亚洲| 72种姿势欧美久久久久大黄蕉| 国产免费久久精品丫丫| 欧洲成人午夜精品无码区久久| 国产精品免费久久久久电影网| 久久精品国产亚洲αv忘忧草| 国产亚洲美女精品久久久久狼|