hdu-acm steps FatMouse's Speed
本想用暴力法先试试的,案例和自己找的数据都过掉了,但是始终wa,本来期待的是tle,结果始终wa。所以也就懒的管了,直接用dp来做了。主要是因为最近在刷暴力法和dp这两个专题,所以才想好好利用一下这道题。如果有哪位发现了我的第一个程序的错误,还望告知。
暴力法(此程序不知道为何wa)
1 #include"iostream"
2 #include"stdio.h"
3 #include"string.h"
4 #include"cmath"
5 #include"algorithm"
6 #define mx 1005
7 using namespace std;
8 int cur[mx];
9 int end1[mx];
10 struct node
11 {
12 int v;
13 int w;
14 int num;
15 }mice[mx];
16 node temp;
17 bool cmp(const node a,const node b)
18 {
19 if(a.w!=b.w) return a.w<b.w;
20 else return a.v>b.v;
21 }
22 int main()
23 {
24 int i,j,k,sum=0;
25 // while(1){
26 while(scanf("%d%d",&mice[sum].w,&mice[sum].v)==2) {mice[sum].num=sum+1;sum++;}
27 sort(mice,mice+sum,cmp);
28 int maxsum=0;
29 for(i=0;i<sum;i++)
30 {
31 k=0;
32 for(j=i;j<sum;j++)
33 {
34 if(j==i)
35 {cur[k]=mice[j].num;temp=mice[i];}
36 else if(temp.v>mice[j].v&&temp.w!=mice[j].w)
37 {
38 cur[++k]=mice[j].num;
39 temp=mice[j];
40 }
41 }
42 if(k+1>maxsum) {memcpy(end1,cur,sizeof(cur));maxsum=k+1;}
43 }
44 cout<<maxsum<<endl;
45 for(i=0;i<maxsum;i++)
46 cout<<end1[i]<<endl;
47 // }
48 return 0;
49 }
接下来是ac掉的简单dp:这道题的思路其实很简单,是一个典型的dp问题——最长上升子序列问题。状态转移方程为
if(dp[j]+1>dp[i])dp[i]=dp[j]+1.用一个pre数组来记录每一个i对应的前一个j,用于后面回溯,将路径存入path中。maxlen用于记录最长上升子序列的长度。maxindex用于记录最长上升子序列对应的最大的i。
#include"iostream"
#include"stdio.h"
#include"cmath"
#include"algorithm"
#include"string.h"
#define mx 1005
using namespace std;
struct node
{
int w,v,index;
}mouse[mx];
int dp[mx];//记录每个以第i个数据结尾的符合要求的子列长度
int pre[mx];//记录i对应的上一个数据
int path[mx];//存放最终结果的下标
int maxlen;//最长序列的长度
int maxindex;//最长序列的最后一个数下标
bool cmp(const node a,const node b)
{
if(a.w!=b.w) return a.w<b.w;
else return a.v>b.v;
}
int main()
{
int i,j,k=;
while(scanf("%d%d",&mouse[k].w,&mouse[k].v)==)
{
dp[k]=;
pre[k]=;
mouse[k].index=k;//存放未排序前的序列号,因为结果需要输出的是这个序列号
k++;
}
sort(mouse+,mouse+k,cmp);//以重量从小到大为第一要求,速度从大到小为第二要求排序
maxlen=;
for(i=;i<k;i++)
{
for(j=;j<i;j++)
{
if(mouse[i].w>mouse[j].w&&mouse[i].v<mouse[j].v&&dp[j]+>dp[i])
{
dp[i]=dp[j]+;
pre[i]=j;//一第i个数据位末尾数据的前一个数据的小标是j,用于回溯
if(dp[i]>maxlen)//更新maxlen和maxindex
{
maxlen=dp[i];
maxindex=i;
}
}
}
}
i=;
while(maxindex) //回溯找到原始下标的序列
{
path[i++]=maxindex;
maxindex=pre[maxindex];
}
cout<<i<<endl;
while(i)
{
i--;
cout<<mouse[path[i]].index<<endl;
}
return ;
}
hdu-acm steps FatMouse's Speed的更多相关文章
- HDU 1160:FatMouse's Speed(LIS+记录路径)
FatMouse's Speed Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) ...
- (hdu)1160 FatMouse's Speed
Problem Description FatMouse believes that the fatter a mouse is, the faster it runs. To disprove th ...
- hdu acm steps Big Event in HDU
上网搜了一下这道题的解法,主要有两个方法,一种是采用母函数的方法,一种是采用0/1背包的方法. 先说一下母函数,即生成函数,做个比喻,母函数就是一个多项式前面的系数的一个整体的集合,而子函数就是这个多 ...
- HDU ACM 1078 FatMouse and Cheese 记忆化+DFS
题意:FatMouse在一个N*N方格上找吃的,每一个点(x,y)有一些吃的,FatMouse从(0,0)的出发去找吃的.每次最多走k步,他走过的位置能够吃掉吃的.保证吃的数量在0-100.规定他仅仅 ...
- hdu ACM Steps Section 1 花式A+B 输入输出格式
acm与oi很大的一个不同就是在输入格式上.oi往往是单组数据,而acm往往是多组数据,而且题目对数据格式往往各有要求,这8道a+b(吐槽..)涉及到了大量的常用的输入输出格式.https://wen ...
- HDU - 1160 (FatMouse's Speed )最长上升子序列
题意:一个元素有两个属性 w 和 sp 求在w严格递增的情况下 sp严格递减 用结构体 定义三个参数 w sp ix , ix是在输入时的顺序 因为我们要排序 之后把结构体数组 按从小到大排序 ...
- (最长上升子序列 并记录过程)FatMouse's Speed -- hdu -- 1160
http://acm.hdu.edu.cn/showproblem.php?pid=1160 FatMouse's Speed Time Limit: 2000/1000 MS (Java/Other ...
- HDU 1160 FatMouse's Speed(要记录路径的二维LIS)
FatMouse's Speed Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) ...
- HDU 1160 FatMouse's Speed (DP)
FatMouse's Speed Time Limit:1000MS Memory Limit:32768KB 64bit IO Format:%I64d & %I64u Su ...
随机推荐
- git无法clone远程代码库及git代理设置
git作为一个版本管理神器,日常工作中自然也就少不了了:特别是Android开发,github和google是逃不过的了.然而很多时候需要用到git克隆远程的代码库,众所周知的原因google.and ...
- Windbg程序调试--转载
WinDbg是微软发布的一款相当优秀的源码级(source-level)调试工具,可以用于Kernel模式调试和用户模式调试,还可以调试Dump文件. WinDbg是微软很重要的诊断调试工具: 可以查 ...
- Codeforces7C 扩展欧几里得
Line Time Limit: 1000MS Memory Limit: 262144KB 64bit IO Format: %I64d & %I64u Submit Status ...
- Cookie的使用与实现记住用户名案例
学习web开发,使用Cookie是不可避免的,个人感觉Cookie的使用和ASP.NET中的Session非常像,只不过Cookie是保存在客户端,而Session是在服务器端,两者都以记录信息为目的 ...
- 消息队列入门(三)JMS标准及实现
>>消息中间件 消息中间件即Message-oriented middleware(MOM),消息中间件利用高效可靠的消息传递机制进行平台无关的数据交流,并基于数据通信来进行分布式系统的集 ...
- 微信公众平台网页获取用户OpenID方法
下面我们一起来看看关于微信公众平台网页获取用户OpenID方法,有需要了解的朋友可以一起来看看吧.用户点击微信自定义菜单view类型按钮后,微信客户端将会打开开发者在按钮中填写的url值 (即网页链接 ...
- 用VMware9 安装 mac 10.8和10.9搜集的资料
VMware9虚拟机安装MAC OS X Mountain Lion 10.8.2详细图文教程 http://diybbs.zol.com.cn/1/34037_699.html vmware too ...
- C++的那些事:流与IO类
1.流的概念 "流"就是"流动",是物质从一处向另一处流动的过程,比如我们能感知到的水流.C++的流是指信息从外部输入设备(如键盘和磁盘)向计算机内部(即内存) ...
- Hadoop开发中,如何开启、关闭控制台打印调试信息
第一种方法: 修改$HADOOP_CONF_DIR/log4j.properties文件 hadoop.root.logger=ALL,console 第二种方法 开启:export HADOOP_R ...
- 【maven 报错】maven项目update之后报错One or more constraints have not been satisfied.
在右键项目Update Project之后报错:One or more constraints have not been satisfied.Spring 4.1 requires Java 1.6 ...