解决leetcode第3782题交替删除操作后最后剩下的整数

3782.交替删除操作后最后剩下的整数

难度:困难

问题描述:

给你一个整数n。

我们将1到n的整数按从左到右的顺序排成一个序列。然后,交替地执行以下两种操作,直到只剩下一个整数为止,从操作1开始:

操作1:从左侧开始,隔一个数删除一个数。

操作2:从右侧开始,隔一个数删除一个数。

返回最后剩下的那个整数。

示例1:

输入:n=8

输出:3

解释:

写下序列[1,2,3,4,5,6,7,8]。

从左侧开始,我们删除每隔一个数字:[1,2,3,4,5,6,7,8]。剩下的整数是[1,3,5,7]。

从右侧开始,我们删除每隔一个数字:[1,3,5,7]。剩下的整数是[3,7]。

从左侧开始,我们删除每隔一个数字:[3,7]。剩下的整数是[3]。

示例2:

输入:n=5

输出:1

解释:

写下序列[1,2,3,4,5]。

从左侧开始,我们删除每隔一个数字:[1,2,3,4,5]。剩下的整数是[1,3,5]。

从右侧开始,我们删除每隔一个数字:[1,3,5]。剩下的整数是[1,5]。

从左侧开始,我们删除每隔一个数字:[1,5]。剩下的整数是[1]。

示例3:

输入:n=1

输出:1

解释:

写下序列[1]。

最后剩下的整数是1。

提示:

1<=n<=1015

问题分析:

这个问题主要完成两个操作,一是从左侧开始,向右隔一个数删除一个数,并返回处理之后的结果。二是从右侧开始,向左隔一个数删除一个数,并返回处理之后的结果。这两个操作用python列表切片操作可以快速完成,设计的两个函数分别是operate_to_right(a)和operate_to_left(a)。然后通过这两个函数,构造循环对原始的列表交替进行删除操作,得到最后剩下的那个数,问题得到解决。

程序如下:

python 复制代码
#从列表a左侧开始,向右隔一个数删除一个数,返回处理之后的结果
def operate_to_right(a):
    return a[::2]

#从列表a右侧开始,向左隔一个数删除一个数,返回处理之后的结果
def operate_to_left(a):
    return a[::-2][::-1]

#主程序
n=int(input('pls input n='))
a=list(range(1,n+1))
while len(a)>1:
    b=operate_to_right(a)
    print(f'从{a}左侧开始,向右每隔一个数删除一个数字,剩下的整数是{b}')
    a=operate_to_left(b)
    print(f'从{b}右侧开始,向左每隔一个数删除一个数字,剩下的整数是{a}')
print(f'最后剩下的数字是{a[0]}')

运行实例一

pls input n=1

最后剩下的数字是1

运行实例二

pls input n=3

从[1, 2, 3]左侧开始,向右每隔一个数删除一个数字,剩下的整数是[1, 3]

从[1, 3]右侧开始,向左每隔一个数删除一个数字,剩下的整数是[3]

最后剩下的数字是3

运行实例三

pls input n=9

从[1, 2, 3, 4, 5, 6, 7, 8, 9]左侧开始,向右每隔一个数删除一个数字,剩下的整数是[1, 3, 5, 7, 9]

从[1, 3, 5, 7, 9]右侧开始,向左每隔一个数删除一个数字,剩下的整数是[1, 5, 9]

从[1, 5, 9]左侧开始,向右每隔一个数删除一个数字,剩下的整数是[1, 9]

从[1, 9]右侧开始,向左每隔一个数删除一个数字,剩下的整数是[9]

最后剩下的数字是9

相关推荐
NAGNIP16 小时前
万字长文!回归模型最全讲解!
算法·面试
知乎的哥廷根数学学派16 小时前
面向可信机械故障诊断的自适应置信度惩罚深度校准算法(Pytorch)
人工智能·pytorch·python·深度学习·算法·机器学习·矩阵
且去填词17 小时前
DeepSeek :基于 Schema 推理与自愈机制的智能 ETL
数据仓库·人工智能·python·语言模型·etl·schema·deepseek
人工干智能17 小时前
OpenAI Assistants API 中 client.beta.threads.messages.create方法,兼谈一星*和两星**解包
python·llm
databook17 小时前
当条形图遇上极坐标:径向与圆形条形图的视觉革命
python·数据分析·数据可视化
阿部多瑞 ABU17 小时前
`chenmo` —— 可编程元叙事引擎 V2.3+
linux·人工智能·python·ai写作
acanab18 小时前
VScode python插件
ide·vscode·python
666HZ66618 小时前
数据结构2.0 线性表
c语言·数据结构·算法
知乎的哥廷根数学学派18 小时前
基于生成对抗U-Net混合架构的隧道衬砌缺陷地质雷达数据智能反演与成像方法(以模拟信号为例,Pytorch)
开发语言·人工智能·pytorch·python·深度学习·机器学习
实心儿儿19 小时前
Linux —— 基础开发工具5
linux·运维·算法