博客
关于我
HDU - 1160 最长上升子序列以及记录路径
阅读量:287 次
发布时间:2019-03-03

本文共 542 字,大约阅读时间需要 1 分钟。

首先,我需要将所有老鼠按照重量从大到小排序。然后,观察它们的速度变化。由于题目要求证明重量越大,速度越小,因此我需要确保在排序后,速度确实呈现递减的趋势。如果速度并非严格递减,可能需要重新调整排序方式或者考虑其他因素。

接下来,我可以使用最长上升子序列(LIS)的方法来找出最长的递减子序列。这里,我需要将速度从小到大排序,然后根据重量来确定子序列的顺序。通过遍历每一只老鼠,我可以检查其重量是否满足递减条件,从而构建最长的子序列。

在实际操作中,我可能会使用一个数组来记录最长子序列的长度,以及另一个数组来记录每个位置的索引。对于每一只老鼠,我会查找它在已经排序后的子序列中的位置,并更新数组。这样,最终我可以确定最长子序列的长度,也就是最多能有多少只老鼠符合条件。

为了确保算法的正确性,我需要反复测试,检查是否存在逻辑错误或者计算错误。特别是在处理边界条件,比如所有老鼠的重量相同或速度相同时,算法是否能正确处理。

最后,通过分析最长子序列的路径,我可以确定具体是哪几只老鼠满足条件,并说明它们的重量和速度情况。这样就能完整地回答题目,证明重量与速度的关系,并找出最多的老鼠数量和具体的老鼠编号。

通过以上步骤,我相信能够系统地解决这个问题,找出正确的答案并清晰地展示整个过程。

转载地址:http://fgsl.baihongyu.com/

你可能感兴趣的文章
Objective-C实现gamma recursive伽玛递归算法(附完整源码)
查看>>
Objective-C实现gamma 伽玛功能算法(附完整源码)
查看>>
Objective-C实现gauss easte高斯复活节日期算法(附完整源码)
查看>>
Objective-C实现gaussian filter高斯滤波器算法(附完整源码)
查看>>
Objective-C实现gaussian naive bayes高斯贝叶斯算法(附完整源码)
查看>>
Objective-C实现gaussian高斯算法(附完整源码)
查看>>
Objective-C实现geometric series几何系列算法(附完整源码)
查看>>
Objective-C实现getline函数功能(附完整源码)
查看>>
Objective-C实现gnome sortt侏儒排序算法(附完整源码)
查看>>
Objective-C实现graph list图列算法(附完整源码)
查看>>
Objective-C实现GraphEdge图边算法(附完整源码)
查看>>
Objective-C实现GraphVertex图顶点算法(附完整源码)
查看>>
Objective-C实现greatest common divisor最大公约数算法(附完整源码)
查看>>
Objective-C实现greedy coin change贪心硬币找零算法(附完整源码)
查看>>
Objective-C实现greedy knapsack贪婪的背包算法(附完整源码)
查看>>
Objective-C实现GridGet算法(附完整源码)
查看>>
Objective-C实现half adder半加器算法(附完整源码)
查看>>
Objective-C实现hamiltonianCycle哈密尔顿图算法(附完整源码)
查看>>
Objective-C实现hamming code汉明码算法(附完整源码)
查看>>
Objective-C实现hamming numbers汉明数算法(附完整源码)
查看>>