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

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

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

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

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

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

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

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

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

你可能感兴趣的文章
Objective-C实现logistic regression逻辑回归算法(附完整源码)
查看>>
Objective-C实现logistic sigmoid函数(附完整源码)
查看>>
Objective-C实现longest Common Substring最长公共子串算法(附完整源码)
查看>>
Objective-C实现longest increasing subsequence最长递增子序列算法(附完整源码)
查看>>
Objective-C实现longestCommonSubsequence最长公共子序列算法(附完整源码)
查看>>
Objective-C实现LongestIncreasingSubsequence最长递增子序列算法(附完整源码)
查看>>
Objective-C实现lorenz transformation 洛伦兹变换算法(附完整源码)
查看>>
Objective-C实现Lower-Upper Decomposition上下分解算法(附完整源码)
查看>>
Objective-C实现LowerCaseConversion小写转换算法(附完整源码)
查看>>
Objective-C实现lowest common ancestor最低共同祖先算法(附完整源码)
查看>>
Objective-C实现LRU 缓存算法(附完整源码)
查看>>
Objective-C实现LRU缓存(附完整源码)
查看>>
Objective-C实现LRU(least recently used)算法(附完整源码)
查看>>
Objective-C实现lstm prediction预测算法(附完整源码)
查看>>
Objective-C实现lucas数列算法(附完整源码)
查看>>
Objective-C实现Luhn (Mod 10)Algorithm算法(附完整源码)
查看>>
Objective-C实现LZW编码(附完整源码)
查看>>
Objective-C实现MAC桌面暗水印(附完整源码)
查看>>
Objective-C实现mandelbrot曼德勃罗特集算法(附完整源码)
查看>>
Objective-C实现markov chain马尔可夫链算法(附完整源码)
查看>>