欧美三区_成人在线免费观看视频_欧美极品少妇xxxxⅹ免费视频_a级毛片免费播放_鲁一鲁中文字幕久久_亚洲一级特黄

二路單調自增子序列模型【acdream 1216】

系統 2132 0

?題目: acdream 1216? Beautiful People


題意:每一個人有兩個值,能力值和潛力值,然后要求一個人的這兩個值都嚴格大于第二個人的時候,這兩個人才干呆在一塊兒,給出很多人的值,求最多有多少個人?


分析:非常easy想到是個單調非增模型,假設用O(n*n)的寫法的話,會超時!

那么我們就要用二分優化來找。

我們能夠先按第一個值 x 從小到大排序,然后按第二個值從大到小排序,這種話找出的最長個數是沒有錯的。(想想為什么)

假如這樣一個例子:

5

1 10

2 12

3 5

3 1

4 3

6 7

首先dp數組僅僅有第一,二組例子:1 10 和2 12

然后第三個例子替換第一組:3 5 和 2 12 ?,看看這組例子,發現不滿足,可是他總的長度不會變,可是這樣保存的話能保證后面出來的數可以最長。所以要想辦法保存路徑

然后第四組例子替換第三組:3 1 和 2 12?

然后第5組例子替換第二組: 3 1 ?和 4 3 是不是滿足條件了,并且最大值值變的更小了,

然后第六組例子加在后面:3 1 和 4 3 和 6 7 ,最大值

最后全部值的二分搜索的值為:1 2 1 1 2 3?

那么發現保存路徑也簡單了。

然后從這個值里面輸出一個遞減的初始數組標號就能夠了、


AC代碼:

      #include <cstdio>
#include <cstring>
#include <string>
#include <iostream>
#include <algorithm>
using namespace std;
const int inf = 0x3f3f3f3f;
const int N = 110000;
struct Node
{
    int x,y;
    int num,count;
};
Node a[N];
int cmp(Node a,Node b)
{
    if(a.x!=b.x)
        return a.x<b.x;
    if(a.y!=b.y)
        return a.y>b.y;
}
int dp[N],mark[N];

int Bin_Search(int l,int r,int x)
{
    while(l<=r)
    {
        int mid = (l+r)/2;   //假如要求相等的情況下,返回較小的值。
        if(dp[mid]==x)
            return mid;
        else if(dp[mid]<=x)
            l=mid+1;
        else
            r=mid-1;
    }
    return l;
}
int main()
{
    int n;
    while(~scanf("%d",&n))
    {
        memset(dp,0,sizeof(dp));
        for(int i=1;i<=n;i++)
        {
            scanf("%d%d",&a[i].x,&a[i].y);
            a[i].num=i;
        }
        sort(a+1,a+n+1,cmp);
        memset(dp,0x3f3f3f3f,sizeof(dp));
        int ans=0;
        int len = 1;
        for(int i=1;i<=n;i++)
        {
            int tmp=Bin_Search(1,len,a[i].y);           //lower_bound(dp+1,dp+1+n,a[i].y)-dp;
            if(tmp==len)
                len++;
            dp[tmp] = a[i].y;
            mark[i] = tmp;
            ans = max(ans,tmp);
        }
        printf("%d\n",ans);
        for(int i=n;i>=1;i--)
        {
            //printf("xx%d ",mark[i]);
            if(mark[i]==ans)
            {
                printf("%d",a[i].num);
                if(ans!=1)
                    printf(" ");
                ans--;
            }
        }
        printf("\n");
    }
    return 0;
}

    


二路單調自增子序列模型【acdream 1216】


更多文章、技術交流、商務合作、聯系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號聯系: 360901061

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對您有幫助就好】

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長會非常 感謝您的哦!!!

發表我的評論
最新評論 總共0條評論
主站蜘蛛池模板: 日韩中文一区二区三区 | 欧美高清色视频在线播放 | 99re在线观看 | 波多野结衣在线看片 | 欧美激情视频网站 | 911网站大全在线观看 | 色秀视频免费网站在线观看 | 一级看片 | www.av在线| 色www精品视频在线观看 | 91久久艹 | 亚洲综合精品成人 | 日韩深夜福利视频 | 在线一级片 | 国产一区二区三区不卡在线观看 | 久久亚洲精品玖玖玖玖 | 国外成人在线视频网站 | 日韩福利视频导航 | 久久99精品久久久久久臀蜜桃 | 一级毛片不卡片免费观看 | 香港三级大全 | 成人性视频免费网站 | 黄色一级网站 | 国产精品极品美女自在线看免费一区二区 | 成年网站在线观看 | a欧美 | 日韩三及片 | 日日操网站 | 在线无码 | 国产精品久久久久久久久久久久 | 污片免费看 | 国内精品视频免费观看 | 国产vr一区二区在线观看 | 噜噜噜噜狠狠狠7777视频 | 在线免费国产 | 成人黄色免费视频 | 色大18成网站www在线观看 | 狠狠色狠狠色综合日日2019 | 日韩中文字 | 久久99亚洲综合精品首页 | 91aiai.com |