【重构数组,形成排列的最大长度】

题目描述

对一个长度为n的数组,某个数加一的同时对另一个数减一,任意次操作后数组最长的排序子序列的长度是多少?

新数组的元素不能为0

思路

数组的元素和是固定的,suma

将列表和suma 重新分配给lenth = n 的列表,求能组成的排列(1,2,3,4,5,...,k,...)的最大长度k

因为新数组的元素不能为0,预先给每个位置留下1

相当于放豆子游戏,n个位置,一共有suma颗豆子,每个位置先放一个豆子,剩下的位置,下标为i的地方放i个豆子,如果下标为i的地方不够i个豆子了,说明最大的排列就到i

如果每个位置都放完了,还有剩下豆子,那这部分剩下的就需要都放在最后一个位置,前面n-1个可以构成排列。

代码

python 复制代码
# 将列表和suma 重新分配给lenth = n 的列表,求能组成的排列(1,2,3,4,5,...,k,...)的最大长度k

def ans(arr):
    suma = sum(arr)
    n = len(arr)
    suma -= n
    for i in range(1, n):
        if suma < i :
            return i
        suma -= i
    if suma == 0:
        return n    
    return n-1


print(ans([2]))
相关推荐
电鱼智能的电小鱼11 小时前
基于电鱼 AI 工控机的智慧工地视频智能分析方案——边缘端AI检测,实现无人值守下的实时安全预警
网络·人工智能·嵌入式硬件·算法·安全·音视频
孫治AllenSun12 小时前
【算法】图相关算法和递归
windows·python·算法
格图素书13 小时前
数学建模算法案例精讲500篇-【数学建模】DBSCAN聚类算法
算法·数据挖掘·聚类
DashVector14 小时前
向量检索服务 DashVector产品计费
数据库·数据仓库·人工智能·算法·向量检索
AI纪元故事会14 小时前
【计算机视觉目标检测算法对比:R-CNN、YOLO与SSD全面解析】
人工智能·算法·目标检测·计算机视觉
夏鹏今天学习了吗14 小时前
【LeetCode热题100(59/100)】分割回文串
算法·leetcode·深度优先
卡提西亚14 小时前
C++笔记-10-循环语句
c++·笔记·算法
还是码字踏实14 小时前
基础数据结构之数组的双指针技巧之对撞指针(两端向中间):三数之和(LeetCode 15 中等题)
数据结构·算法·leetcode·双指针·对撞指针
Coovally AI模型快速验证16 小时前
当视觉语言模型接收到相互矛盾的信息时,它会相信哪个信号?
人工智能·深度学习·算法·机器学习·目标跟踪·语言模型
电院工程师17 小时前
SIMON64/128算法Verilog流水线实现(附Python实现)
python·嵌入式硬件·算法·密码学