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

题目描述

对一个长度为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]))
相关推荐
Hello娃的2 分钟前
【神经网络】反向传播BP算法
人工智能·神经网络·算法
lynnlovemin7 分钟前
从暴力到高效:C++ 算法优化实战 —— 排序与双指针篇
java·c++·算法
jinxinyuuuus13 分钟前
快手在线去水印:短链解析、API逆向与视频流的元数据重构
前端·人工智能·算法·重构
Flash.kkl18 分钟前
优先算法专题十五——BFS_FloodFill
算法·宽度优先
高洁0125 分钟前
向量数据库拥抱大模型
python·深度学习·算法·机器学习·transformer
慕容青峰27 分钟前
牛客小白月赛 103 C 题题解
c++·算法·sublime text
小龙报28 分钟前
【算法通关指南:算法基础篇(四)】二维差分专题:1.【模板】差分 2.地毯
c语言·数据结构·c++·深度学习·神经网络·算法·自然语言处理
立志成为大牛的小牛29 分钟前
数据结构——五十八、希尔排序(Shell Sort)(王道408)
数据结构·学习·程序人生·考研·算法·排序算法
代码游侠35 分钟前
学习笔记——文件I/O
linux·数据库·笔记·学习·算法