解决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

相关推荐
测试19983 小时前
软件测试 - 单元测试总结
自动化测试·软件测试·python·测试工具·职场和发展·单元测试·测试用例
曲幽5 小时前
我用了FastApiAdmin后,连夜把踩过的坑都整理出来了
redis·python·postgresql·vue3·fastapi·web·sqlalchemy·admin·fastapiadmin
心中有国也有家7 小时前
cann-recipes-infer:昇腾 NPU 推理的“菜谱集合”
经验分享·笔记·学习·算法
前端若水7 小时前
会话管理:创建、切换、删除对话历史
前端·人工智能·python·react.js
绝知此事7 小时前
【算法突围 01】线性结构与哈希表:后端开发的收纳术
java·数据结构·算法·面试·jdk·散列表
碧海银沙音频科技研究院7 小时前
通话AEC与语音识别AEC的软硬回采链路
深度学习·算法·语音识别
涛声依旧-底层原理研究所8 小时前
残差连接与层归一化通俗易懂的详解
人工智能·python·神经网络·transformer
csdn_aspnet8 小时前
Python 算法快闪 LeetCode 编号 70 - 爬楼梯
python·算法·leetcode·职场和发展
fantasy_arch8 小时前
pytorch人脸匹配模型
人工智能·pytorch·python