HDU - 1160 FatMouse's Speed 【DP】
2024-08-25 07:39:40
题目链接
http://acm.hdu.edu.cn/showproblem.php?pid=1160
题意
给出一系列的 wi si
要找出一个最长的子序列 满足
wi 是按照升序排列的
si 是按照 降序排列的
思路
因为有双关键词
我们 可以先将一关键词 比如 W 按照 升序排序
再根据 S 关键词 来找 最长下降子序列 就可以了
要输出 其中的一个子序列 我们只要 记录 其 父节点就可以
再循环网上找
AC代码
#include <cstdio>
#include <cstring>
#include <ctype.h>
#include <cstdlib>
#include <cmath>
#include <climits>
#include <ctime>
#include <iostream>
#include <algorithm>
#include <deque>
#include <vector>
#include <queue>
#include <string>
#include <map>
#include <stack>
#include <set>
#include <list>
#include <numeric>
#include <sstream>
#include <iomanip>
#include <limits>
#define CLR(a, b) memset(a, (b), sizeof(a))
#define pb push_back
using namespace std;
typedef long long ll;
typedef long double ld;
typedef unsigned long long ull;
typedef pair <int, int> pii;
typedef pair <ll, ll> pll;
typedef pair<string, int> psi;
typedef pair<string, string> pss;
const double PI = acos(-1.0);
const double E = exp(1.0);
const double eps = 1e-8;
const int INF = 0x3f3f3f3f;
const int maxn = 1e3 + 5;
const int MOD = 1e9 + 7;
struct node
{
int w, s;
int id;
}q[maxn];
bool comp(node x, node y)
{
if(x.w == y.w)
return x.s > y.s;
return x.w < y.w;
}
int dp[maxn];
int pre[maxn];
int main()
{
int pos = 1;
while (~scanf("%d%d", &q[pos].w, &q[pos].s))
q[pos].id = pos++;
sort(q, q + pos, comp);
int ans = 1;
CLR(dp, 0);
CLR(pre, 0);
for (int i = 1; i <= pos; i++)
{
dp[i] = 1;
for (int j = 1; j < i; j++)
{
if (q[i].s < q[j].s && q[i].w > q[j].w)
{
if (dp[j] + 1 > dp[i])
{
dp[i] = dp[j] + 1;
pre[i] = j;
}
}
}
ans = max(ans, dp[i]);
}
printf("%d\n", ans);
vector <int> v;
for (int i = 1; i <= pos; i++)
{
if (dp[i] == ans)
{
int vis = i;
v.pb(q[vis].id);
while (pre[vis])
{
v.pb(q[pre[vis]].id);
vis = pre[vis];
}
break;
}
}
vector <int>::iterator it;
for (it = v.end(), it--; ; it--)
{
printf("%d\n", *it);
if (it == v.begin())
break;
}
}
最新文章
- 高可用mysql之MHA的原理
- C# 统计在线人数和总访问人数
- PHP 数据安全问题总结
- JS中isPrototypeOf 和hasOwnProperty 的区别
- WordPress实现登录或退出后直接跳转到首页的方法
- Oracle LPAD/RPAD函数在处理中文时的注意事项
- table设置滚动条
- 判断线段和直线相交 POJ 3304
- 【Away3D代码解读】(四):主要模块简介
- (转载)SQL中导入图片
- AES加密跨平台出现的问题
- java 添加一个线程、创建响应的用户界面 。 演示示例代码
- Oracle查询速度慢的原因总结
- Linux程序设计中的curses.h编译报错,无法找到curses.h和ncurses.h
- JVM启动参数设置
- hdu1051 Wooden Sticks---贪心
- [面试]volatile类型修饰符/内存屏障/处理器缓存
- 自定义UIPickView
- 2019.4 sigfox EMC
- ethereum/EIPs-100 挖矿难度计算