• <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 閱讀(152) 評論(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
            • 評論內容較長,點擊標題查看
            • --王私江
            国内精品久久久久影院优| 久久国产视屏| 久久亚洲精品中文字幕| 久久偷看各类wc女厕嘘嘘| 久久99国产精一区二区三区 | 精品人妻伦九区久久AAA片69| 久久久久久精品久久久久| 国产人久久人人人人爽| 亚洲国产高清精品线久久| 99久久国语露脸精品国产| 亚洲欧美成人久久综合中文网| 久久99热狠狠色精品一区| 99久久国产宗和精品1上映| 精品久久久久中文字幕一区| 中文字幕日本人妻久久久免费| 伊人久久综合热线大杳蕉下载| 亚洲欧美成人综合久久久 | 久久精品亚洲一区二区三区浴池| 国产AV影片久久久久久| 无码人妻久久一区二区三区免费| 久久精品无码专区免费 | 亚洲AV日韩精品久久久久久| 狠狠久久综合伊人不卡| 996久久国产精品线观看| 亚洲精品乱码久久久久久蜜桃不卡 | 国产精品va久久久久久久| 色婷婷综合久久久久中文| 伊人久久大香线蕉成人| 久久综合精品国产一区二区三区| 青青草原1769久久免费播放| 久久亚洲精品成人av无码网站| 99久久做夜夜爱天天做精品| 久久亚洲精品无码观看不卡| 久久精品国产色蜜蜜麻豆| 91久久香蕉国产熟女线看| 91精品国产91久久久久久青草| 久久w5ww成w人免费| 97久久精品国产精品青草| 国产精品一久久香蕉国产线看观看| 色综合久久中文字幕无码| 午夜精品久久久久久久|