HDOJ1160 Fat Mouse's Speed

FatMouse‘s Speed

pid=1160">http://acm.hdu.edu.cn/showproblem.php?pid=1160

最长递增子序列问题的一个变体。实际上跟最长递增子序列问题没有不论什么本质的差别。

定义一个结构体mice,设mice[i].w表示第i仅仅老鼠的重量,mice[i].s表示第i仅仅老鼠的速度。对mice结构体进行排序。以w为第一keyword,递增。s为第二keyword,递减。设dp[i]表示以mice[i]为结尾的最长序列的长度。考虑某一个dp[i]。则有:

dp[i] = max(dp[i], dp[j]+1) (1<=j<i,且mice[i].w>mice[j].w。mice[i].s < mice[j].s)

当中,初始条件为dp[i]=1 (i=1, 2, ..., n)

排序的过程中须要加一个变量记录其原始的位置,由于终于的输出是原始的排序。

贴上AC代码:

#include<iostream>
#include<algorithm>
using namespace std;
struct mouse
{
	int w;
	int s;
	int index;
};
    mouse mice[1005];
	int dp[1005];//dp[i]表示以mice[i]为结尾的最长递增子序列
    int pre[1005];//pre[i]记录i的上一个数据
    int res[1005];//存放终于的结果
bool cmp(mouse a,mouse b)
{
	if(a.w!=b.w)
	return a.w<b.w;
	return a.s>b.s;
}

int main()
{
    freopen("1160.in","r",stdin);
    freopen("1160.out","w",stdout);
	int i=1,j;
	while(cin>>mice[i].w>>mice[i].s)
	{
		dp[i]=1;
		pre[i]=0;
		mice[i].index=i;
		i++;
	}
	int n=i-1;
	sort(mice+1,mice+1+n,cmp);
	int maxlen=0;//最长序列长度
	int end;//最长序列的末尾下标
	dp[1]=1;
	for(i=1;i<=n;i++)
	{
		for(j=1;j<i;j++)
		{
			if(mice[i].w>mice[j].w&&mice[i].s<mice[j].s&&dp[j]+1>dp[i])
			{
				dp[i]=dp[j]+1;
				pre[i]=j;
				if(dp[i]>maxlen)
				{
					end=i;
					maxlen=dp[i];
				}
			}
		}
	}
	int t=end;
	i=0;
	while(t!=0)
	{
		res[i++]=t;
		t=pre[t];
	}
	cout<<i<<endl;//i指向总数
	while(i>0)
	{
		i--;
		cout<<mice[res[i]].index<<endl;
	}
	return 0;
}

HDOJ1160 Fat Mouse's Speed

时间: 2024-08-06 07:59:13

HDOJ1160 Fat Mouse&#39;s Speed的相关文章

HDOJ 1009. Fat Mouse&#39; Trade 贪心 结构体排序

FatMouse' Trade Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others) Total Submission(s): 56784    Accepted Submission(s): 19009 Problem Description FatMouse prepared M pounds of cat food, ready to trade with the cats g

HDU 1160 FatMouse&amp;#39;s Speed DP题解

本题就先排序老鼠的重量,然后查找老鼠的速度的最长递增子序列,只是由于须要按原来的标号输出,故此须要使用struct把三个信息打包起来. 查找最长递增子序列使用动态规划法.主要的一维动态规划法了. 记录路径:仅仅须要记录后继标号,就能够逐个输出了. #include <stdio.h> #include <algorithm> using namespace std; const int MAX_N = 1005; struct MouseSpeed { int id, w, s;

javascript动画效果之缓冲动画(修改版)

在编写多块同时触发运动的时候,发现一个BUG, timer = setInterval(show, 30);本来show是一个自定义函数,当设为timer = setInterval(show(one,two), 30);时,发现show里面的参数one和two无法被导入,所以需要做以下代码改进和优化 原版的html和css代码在这里javascript动画效果之缓冲动画 js代码如下 1 <script> 2 function $(id) { 3 return typeof id === &

js实现一套代码来控制所有的运动,图片的淡入淡出,winth,height的变宽

介绍了那么多运动,這次一套代码实现所有运动 1.html代码和css代码,只是定义一个div 1 <style> 2 div{ 3 width:200px; 4 height:200px; 5 margin:20px; 6 float:left; 7 background:yellow; 8 border:10px solid black; 9 filter:alpha(opacity:30); 10 opacity:0.3; 11 } 12 </style> 13 <bod

JavaScript的运动框架学习总结

一.目录 1. 入门案例——实现匀速运动 2. 入门案例——实现缓冲运动 3. 实现任意值的运动框架v.1 4. 改进任意值的运动框架v.2 5. 改进任意值的运动框架v.3 6. 实现链式运动框架 7. 实现完美运动框架 二.内容 1. 入门案例——实现匀速运动 ①. 要求:只要简单的实现传入的对象和运动的最终目标,便能操作该对象的left属性的大小匀速的变化到目标大小. ②. 具体代码: 1 <!DOCTYPE html> 2 <html lang="en">

codechef FIBTREE 码农题 线段树 树剖 标记永久化

好烦啊,调了半天 线段树部分标记比较多,手抖打错了一个 剩下的都是取模的问题 我自己瞎jb推的公式里保留了abs,但是在模意义下是gg的,所以必须把正负区分开 调试的时候一定要注意构造各种形状的树,不要只做随机树 随机树深度只有log,很难体现一些链上的性质 我用随机树拍了一下午没出错,一掏出直链就秒秒钟出错 最后找到了那个该死的abs 还是逻辑不够严谨啊 1 #include <bits/stdc++.h> 2 #define DEBUG 0 3 #define mid (l+r>&g

2015 5.16 C# 继承和多态

类的层次结构有两种基本的构造方式  自顶向下  自底向上 基类的保护成员是指允许派生类的方法代码访问,而不是指通过派生类的对象访问 如果基类中的字段通过公有且可读写的属性进行了封装,那么建议将字段定义为私有的,这样包括其派生类在内的所有其他类型都必须通过属性进行访问 隐藏基类成员 如果派生类中定义了与基类相同的成员,默认情况下基类的成员在派生类中会被隐藏,即派生类成员覆盖了基类成员   用new来修饰提高代码可读性 base 关键字,当派生类隐藏了基类成员时,base关键字就能发挥作用:直接写出

Codeforces 845D - Two TVs(贪心)

原题链接:http://codeforces.com/problemset/problem/845/D 题意:一个人在驾照考试中,路边有"限速XX"."没有限速"."可以超车"."不能超车"路牌, 以及这个人在某一时刻开车速度.是否超车,题目按时间顺序输入以上情况,其中可能会有违反交规的情况,但这个人可以狡辩说没看到一些路牌.一开始默认是没有限速而且可以任意超车的. 问他要"假装"没看到几个路牌才能使他&q

我也来写一个贪吃蛇

最近工作量好大,好忙,趁周末练练手,花了近3小时写了一个贪吃蛇. 实现贪吃蛇的功能很简单. 我就分享一下我实现贪吃蛇看起来在界面上移动并且吃食物长大的原理. 我建了一个数组list_arr[]来保存贪吃蛇所在的每个格子的id,并建了2个全局变量x和y,监听贪吃蛇头的位置,当然x和y也是贪吃蛇的起始位置. 那么贪吃蛇移动实际上就是每次从list_arr[]里取出第一个元素(list_arr.shift()方法),取出的第一个元素也可以认为是贪吃蛇的尾巴,然后把这个元素(也就是格子的id)代表的格子