当前位置: 首页 > news >正文

lc1027-最长等差数列

题目描述

  • 给定一个数组,计算最长等差数列的长度

示例

输入:nums = [3,6,9,12]
输出:4
解释:3 6 9 12
输入:nums = [9,4,7,2,10]
输出:3
解释:4 7 10
输入:nums = [20,1,15,3,10,5,8]
输出:4
解释:20 15 10 5

题解

  • 思路:DP
    • f(i,j): 以 i 结尾,公差为 j
    • 结果至少为 2
    • 转移方程:f[i][j] = max(f[i][j], f[k][j] + 1) k<i
func longestArithSeqLength(nums []int) int {n := len(nums)f := make([]map[int]int, n)res := 2for i := 0; i < n; i ++ {for k := 0; k < i; k ++ {j := nums[k] - nums[i]if f[i] == nil { f[i] = map[int]int{} }if f[k] == nil { f[k] = map[int]int{} }if _, ok := f[i][j]; !ok {f[i][j] = 2}if _, ok := f[k][j]; ok {f[i][j] = max(f[i][j], f[k][j] + 1)res = max(res, f[i][j])}}}return res
}
http://www.wxhsa.cn/company.asp?id=4055

相关文章:

  • 13
  • np.zeros函数
  • Langchain之让LLM拥有记忆
  • 25.9.14
  • .net PublishSingleFile 打包程序提取
  • 实用指南:Java类加载机制
  • C 语言注释
  • 扫描线
  • C语言中的查找与排序算法整理
  • k8s练习
  • css-2
  • AtCoder Beginner Contest 423 ABCDEF 题目解析
  • numpy中的shape属性
  • mac 查看fat32磁盘
  • 使用Smart-Doc为Java项目生成gRPC API文档
  • 数字时钟用的什么字体
  • Python数据分析零基础完整课程大纲(详细版)【202509第1版】 - 指南
  • 详细介绍:uni-app 根据用户不同身份显示不同的tabBar
  • VSTO QQ群 61840693 解散通知【新群193203228 】
  • kettle从入门到精通 第107课 ETL之kettle json_input 一个点号引发的血案
  • 【2024-2025第二学期】助教工作学期总结
  • Clion 实现多个 main 函数执行互不影响
  • 腾讯终于对Claude code下手了?我拿它跑完一个真实项目,结果有点意外…
  • 快速利用AI读论文
  • 第一周预习作业(AI)
  • HTTP协议核心概念全解析 - 实践
  • Django过时了吗?从ASGI到AI时代的思考
  • 日常练习一部分
  • 世界史
  • 罗技M275鼠标滚轮断轴维修:建模+3D打印修复全过程