3636 Nested Dolls
题目链接:[http://acm.pku.edu.cn/JudgeOnline/problem?id=3636
](http://acm.pku.edu.cn/JudgeOnline/problem?id=3636)好吧,这题我看了解题报告。而且解题报告有错误的。只考虑w递增,没考虑w值相等的情况。
我自己这里加进去了判断。主要是看解题报告后才知道数据这么弱,就按他的写了
大意是给出N个玩具,要求放k组,其中每组都是大玩偶套小玩偶。在w(宽)和h(高)都大于
另一个玩偶的时候才能套进去问最小的k,就是组数。
先按w升序再按h降序排序,然后一个一个往里插就行了,要稍微注意下判断相等的情况
代码:
#include <iostream>
#include <functional>
#include <cstdio>
#include <algorithm>
using namespace std;
#define MAXN 20002
struct doll
{
int w,h;
};
doll dolls[MAXN];
doll list[20002];
bool cmp(doll a, doll b)
{
if(a.w != b.w)
return a.w < b.w;
return a.h > b.h;
}
int main()
{
int t, m, i, num, l, r, mid;
scanf("%d", &t);
while(t --)
{
scanf("%d", &m);
for(i = 0; i < m; i ++)
scanf("%d %d", &dolls[i].w, &dolls[i].h);
sort(dolls, dolls + m, cmp);
memset(list, 0, sizeof(list));
num = 0;
for(i = 0; i < m; i ++)
{
l = 0;
r = num;
while(l < r)
{
mid = (l + r) / 2;
if((list[mid].w >= dolls[i].w) || list[mid].h >= dolls[i].h)
l = mid + 1;
else
r = mid;
}
if(num == l)
num ++;
list[l].w = dolls[i].w;
list[l].h = dolls[i].h;
}
printf("%d\n", num);
}
return 0;
}
至于 1065 Wooden Sticks 题
都是一样的,去掉了相等的条件(这样简单多了,直接俩个都升序排列就好了)
代码就是改了
return a.h > b.h; 改为 return a.h < b.h;
和
if((list[mid].w >= dolls[i].w) || list[mid].h >= dolls[i].h)
改为if((list[mid].w > dolls[i].w) || list[mid].h > dolls[i].h)
其他的都不变,这里就不重贴了