POJ 1836 Alignment 最長遞增子序列(LIS)的變形

来源:http://www.cnblogs.com/pach/archive/2016/10/31/6017150.html
-Advertisement-
Play Games

大致題意:給出一隊士兵的身高,一開始不是按身高排序的。要求最少的人出列,使原序列計程車兵的身高先遞增後遞減。 求遞增和遞減不難想到遞增子序列,要求最少的人出列,也就是原隊列的人要最多。 1 2 3 4 5 4 3 2 1 這個序列從左至右看前半部分是遞增,從右至左看前半部分也是遞增。所以我們先把從左只 ...


大致題意:給出一隊士兵的身高,一開始不是按身高排序的。要求最少的人出列,使原序列計程車兵的身高先遞增後遞減。

求遞增和遞減不難想到遞增子序列,要求最少的人出列,也就是原隊列的人要最多。

1 2 3 4 5 4 3 2 1

這個序列從左至右看前半部分是遞增,從右至左看前半部分也是遞增。所以我們先把從左只右和從右至左的LIS分別求出來。

如果結果是這樣的:

  A[i]={1.86 1.86 1.30621 2 1.4 1 1.97 2.2} //原隊列

  a[i]={1 1 1 2 2 1 3 4}

  b[i]={3 3 2 3 2 1 1 1}

如果是A[1]~A[i]遞增,A[i+1]~A[8]遞減。此時就是求:a[1]~a[i]之間的一個值與b[i+1]~b[8]之間的一個值的和的最大值。

O(n^2)和O(nlogn)演算法都可以過。

O(n^2)演算法:

#include <iostream>
#include <cstdio>
using namespace std;

const int Max=1e3+5;

int main()
{
    //freopen("in.txt","r",stdin);
    int n;
    scanf("%d",&n);
    double a[Max]={0};
    for(int i=0; i<n; i++)
        scanf("%f",a+i);
    int l[Max]= {0},r[Max]= {0};
    l[0]=r[n-1]=1;
    for(int i = 1; i < n; i++)
    {
        int maxLen = 0;
        for(int j = 0; j < i; j++)
            if(a[j]<a[i])
                maxLen = max(maxLen,l[j]);
        l[i] = maxLen + 1;
    }
    for(int i=n-2; i>=0; i--)
    {
        int maxLen=0;
        for(int j=n-1; j>i; j--)
            if(a[j]<a[i])
                maxLen=max(maxLen,r[j]);
        r[i]=maxLen+1;
    }
    int maxlen=0;
    for(int i=0;i<n-1;i++)
        for(int j=i+1;j<n;j++)
            maxlen=max(maxlen,l[i]+r[j]);
    printf("%d\n",n-maxlen);
    return 0;
}

O(nlogn)演算法

#include <iostream>
#include <cstdio>
using namespace std;

const int Max=1e3+5;
int l[Max]= {0},r[Max]= {0};
double B[Max];
int BinarySearch(double *a, double value, int n)
{
    int low = 0;
    int high = n - 1;
    while(low <= high)
    {
        int mid = (high + low) / 2;
        if(a[mid] == value)
            return mid;
        else if(value<a[mid])
            high = mid - 1;
        else
            low = mid + 1;
    }
    return low;
}
int LIS_DP_NlogN(double *a, int n,int *Len)
{
    int nLISLen = 1;
    B[0] = a[0];
    for(int i = 1; i < n; i++)
    {
        if(a[i] > B[nLISLen - 1])
        {
            B[nLISLen] = a[i];
            nLISLen++;
            Len[i]=nLISLen;
        }
        else
        {
            int pos = BinarySearch(B, a[i], nLISLen);
            B[pos] = a[i];
            Len[i]=pos+1;
        }
    }
    return nLISLen;
}
int main()
{
    //freopen("in.txt","r",stdin);
    int n;
    scanf("%d",&n);
    double a[Max]={0};
    double b[Max]={0};
    l[0]=r[0]=1;
    for(int i=0; i<n; i++)
    {
        scanf("%f",a+i);
        b[n-i-1]=a[i];
    }
    LIS_DP_NlogN(a,n,l);
    LIS_DP_NlogN(b,n,r);
    int maxlen=0;
    for(int i=0;i<n-1;i++)
        for(int j=n-i-2;j>=0;j--)
            maxlen=max(maxlen,l[i]+r[j]);
    printf("%d\n",n-maxlen);
    return 0;
}

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 下麵是 Java 線程相關的熱門面試題,你可以用它來好好準備面試。 1) 什麼是線程? 線程是操作系統能夠進行運算調度的最小單位,它被包含在進程之中,是進程中的實際運作單位。程式員可以通過它進行多處理器編程,你可以使用多線程對運算密集型任務提速。比如,如果一個線程完成一個任務要 100 毫秒,那麼用 ...
  • 如今的互聯網,採集網站非常多,很多網站都喜歡盜鏈/盜用別人網站的圖片,這樣不僅侵犯網權,還導致被盜鏈的網站消耗大量的流量,給伺服器造成比較大的壓力,本文章向大家介紹php如何防止圖片盜用/盜鏈的兩種方法,需要的朋友可以參考一下。 圖片防盜鏈有什麼用? 防止其它網站盜用你的圖片,浪費你寶貴的流量。本文 ...
  • 這次主要是講解一下通過登錄後對得到的數據進行分頁,首先我們新建一個登錄頁面login.jsp,因為我們主要學習一下分頁,所以登錄驗證的部分不再闡述,主要代碼如下: 首先建立實體類User.java並添加get和set方法: 我們可以看到form表單是提交到pageServlet中,所以我們新建一個P ...
  • <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> <html> <head> <base href="http://user-20160821pd:8088/com.jdbc2/"> <title>My JSP 'inde ...
  • 搜索功能 DAO層都是一些資料庫的增刪改查操作 Servlet,控制層 點擊頁面的搜索,把輸入的信息提交到servlet, 實體Bean是針對資料庫中的欄位而建的, 不和資料庫做對應,而是打包一些零散的值的Bean,和它的頁面做對應,包名為:com.xxx.view 針對頁面的實體Bean 頁面亂碼 ...
  • Java的序列化流程如下: Java的反序列化流程如下: 註意:並不是所有類都需要進行序列化,主要原因有兩個 1)安全問題。Java中有的類屬於敏感類,此類的對象數據不便對外公開,而序列化的對象數據很容易進行破解,無法保證其數據的安全性,因此一般這種類型的對象不會進行序列化。 2)資源問題。可以使用 ...
  • 總結一下內置函數,Build-in Function。 一、數學運算類 求絕對值 二、集合類操作 三、邏輯判斷 四、反射 五、IO操作 ...
  • 題目描述 小城和小華都是熱愛數學的好學生,最近,他們不約而同地迷上了數獨游戲,好勝的他 們想用數獨來一比高低。但普通的數獨對他們來說都過於簡單了,於是他們向 Z 博士請教, Z 博士拿出了他最近發明的“靶形數獨”,作為這兩個孩子比試的題目。 靶形數獨的方格同普通數獨一樣,在 9 格寬×9 格高的大九 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...