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

            poj1836

            Alignment

            Time Limit: 1000MS Memory Limit: 30000K
            Total Submissions: 7642 Accepted: 2434

            Description

            In the army, a platoon is composed by n soldiers. During the morning inspection, the soldiers are aligned in a straight line in front of the captain. The captain is not satisfied with the way his soldiers are aligned; it is true that the soldiers are aligned in order by their code number: 1 , 2 , 3 , . . . , n , but they are not aligned by their height. The captain asks some soldiers to get out of the line, as the soldiers that remain in the line, without changing their places, but getting closer, to form a new line, where each soldier can see by looking lengthwise the line at least one of the line's extremity (left or right). A soldier see an extremity if there isn't any soldiers with a higher or equal height than his height between him and that extremity.

            Write a program that, knowing the height of each soldier, determines the minimum number of soldiers which have to get out of line.

            Input

            On the first line of the input is written the number of the soldiers n. On the second line is written a series of n floating numbers with at most 5 digits precision and separated by a space character. The k-th number from this line represents the height of the soldier who has the code k (1 <= k <= n).

            There are some restrictions:
            • 2 <= n <= 1000
            • the height are floating numbers from the interval [0.5, 2.5]

            Output

            The only line of output will contain the number of the soldiers who have to get out of the line.

            Sample Input

            8
            1.86 1.86 1.30621 2 1.4 1 1.97 2.2
            

            Sample Output

            4
            一些士兵站成一排,現在要盡量少的士兵出來,使得剩些的士兵都能看到排左或排右,看到的意思是,中間沒有比它高的
            這個題和合唱隊形差不多,但是有區別,中間的兩個人可以一樣高
            從左到右求最長上升子序列,再右到左求最長上升子序列,
            然后枚舉中間節點,求兩個序列的最大和
            中間兩個一樣高可以,需要特別處理下
             1#include<stdio.h>
             2#include<string.h>
             3#include<math.h>
             4#define eps 0.0000001
             5#define MAX 1005
             6double a[MAX];
             7int f[MAX],f1[MAX];
             8int n,i,j,ans;
             9int max(int a,int b)
            10{
            11    if (a>b) return a;
            12    else return b;
            13}

            14int main()
            15{
            16    scanf("%d",&n);
            17    for (i=1; i<=n ; i++ ) scanf("%lf",&a[i]);
            18    f[1]=1;
            19    for (i=2; i<=n ; i++ )
            20    {
            21        f[i]=1;
            22        for (j=1; j<=i-1 ; j++ )
            23        {
            24            if ((a[i]-a[j])>eps)
            25            {
            26                f[i]=max(f[j]+1,f[i]);
            27            }

            28        }

            29    }

            30    f1[n]=1;
            31    for (i=n-1; i>=1 ; i-- )
            32    {
            33        f1[i]=1;
            34        for (j=n; j>=i+1 ; j-- )
            35        {
            36            if ((a[i]-a[j])>eps)
            37            {
            38                f1[i]=max(f1[i],f1[j]+1);
            39            }

            40        }

            41    }

            42    ans=0;
            43    for (i=1; i<=n ; i++ )
            44    {
            45        ans=max(ans,f[i]+f1[i]-1);
            46        for (j=i+1;j<=n ;j++ )
            47        {
            48            if ((a[i]-a[j])<eps)
            49            {
            50                if (ans<f[i]+f1[j])
            51                {
            52                    ans=f[i]+f1[j];
            53                }

            54                else break;
            55            }

            56        }

            57    }

            58    printf("%d\n",n-ans);
            59    return 0;
            60}

            61///合唱隊形類似
            62
             

            posted on 2012-02-21 13:12 jh818012 閱讀(153) 評論(0)  編輯 收藏 引用

            <2025年7月>
            293012345
            6789101112
            13141516171819
            20212223242526
            272829303112
            3456789

            導航

            統計

            常用鏈接

            留言簿

            文章檔案(85)

            搜索

            最新評論

            • 1.?re: poj1426
            • 我嚓,,輝哥,,居然搜到你的題解了
            • --season
            • 2.?re: poj3083
            • @王私江
              (8+i)&3 相當于是 取余3的意思 因為 3 的 二進制是 000011 和(8+i)
            • --游客
            • 3.?re: poj3414[未登錄]
            • @王私江
              0ms
            • --jh818012
            • 4.?re: poj3414
            • 200+行,跑了多少ms呢?我的130+行哦,你菜啦,哈哈。
            • --王私江
            • 5.?re: poj1426
            • 評論內容較長,點擊標題查看
            • --王私江
            精品国产一区二区三区久久蜜臀| 久久婷婷五月综合色奶水99啪| 91精品国产91久久久久福利| 日日噜噜夜夜狠狠久久丁香五月 | 女人香蕉久久**毛片精品| 国产精品久久久久一区二区三区| 久久久久久亚洲精品不卡| 中文字幕久久久久人妻| 国产福利电影一区二区三区久久老子无码午夜伦不 | 亚洲国产成人精品无码久久久久久综合 | 久久婷婷五月综合97色一本一本 | 91精品国产91热久久久久福利| 波多野结衣久久一区二区| 99久久国产主播综合精品| 久久久久亚洲AV片无码下载蜜桃| 久久国产视频99电影| 2021精品国产综合久久| 欧洲人妻丰满av无码久久不卡 | 91精品国产综合久久久久久| 久久人人爽人人爽人人片AV东京热 | 99久久免费国产特黄| 久久笫一福利免费导航 | 一本色综合久久| 午夜精品久久久久9999高清| 久久99国产精品成人欧美| 国产一级做a爰片久久毛片| 久久亚洲AV成人无码电影| 久久久久精品国产亚洲AV无码| 日日狠狠久久偷偷色综合96蜜桃| 精品一久久香蕉国产线看播放| 88久久精品无码一区二区毛片| 国产精品美女久久久久网| 99久久99久久| 精品国产91久久久久久久a | 亚洲午夜久久久久妓女影院| 精品国产乱码久久久久久呢 | 99久久精品国产毛片| 久久福利片| 精品伊人久久久| 欧美黑人又粗又大久久久| 69久久精品无码一区二区|