經典DP 嵌套矩形

來源:互聯網
上載者:User

    dp初級入門必學,有南陽理工學院OJ的題在此:http://acm.nyist.net/JudgeOnline/problem.php?pid=16

    簡單dp,劉汝佳白書第一本,161頁。稍微理解下就會了。。很easy

#include <cstdio>#include <cstring>#include <algorithm>using namespace std;#define max(a,b)((a)>(b)?(a):(b))#define min(a,b)((a)<(b)?(a):(b))const int maxn = 15;struct Node{int x, y;}node[maxn];int cmp(Node a, Node b){if (a.y == b.y)return a.x > b.x;return a.y > b.y;}int main(){int N;int dp[maxn];scanf("%d", &N);while (N--){int n;scanf("%d", &n);int i, j;for (i=0; i<n; i++){int tmpa, tmpb;scanf("%d %d", &tmpa, &tmpb);node[i].x = min(tmpa, tmpb);node[i].y = max(tmpa, tmpb);}sort(node, node+n, cmp);for (i=n-1; i>=0; i--){dp[i] = 1;for (j=n-1; j>i; j--){if (node[j].x < node[i].x && node[j].y <=node[i].y)if (dp[i] < dp[j] + 1)dp[i] = dp[j] + 1;}}int max = 0;for (i=0; i<n; i++)if (dp[i] > max)max = dp[i];printf("%d\n", max);}return 0;}

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.