第四次作业

本文探讨了Python中元组的概念,展示了元组乘法的特殊行为,不同于数字乘法,它会复制元组元素。同时,解释了拆包过程,通过实例展示了如何将可迭代对象的元素分配给占位符。此外,还提供了一个用于检查字符串是否只包含数字的isdigit函数实现。最后,介绍了LeetCode第5题的解决方案,寻找给定字符串中最长的回文子串。
摘要由CSDN通过智能技术生成

练习题:
1、元组概念
写出下面代码的执行结果和最终结果的类型
(1, 2)*2 (1,2,1,2)
(1, )*2 (1,1)
(1)*2 (2)
分析为什么会出现这样的结果.
元组的乘法与单个数字乘法不同,并不会将数值进行乘积,而且将整体变化,如一个元组2以后变成一个含有双倍数量元素的元组
2、拆包过程是什么?
a, b = 1, 2
上述过程属于拆包吗?
不属于
可迭代对象拆包时,怎么赋值给占位符?
*代表取任意长,这里,但是前后如果有定位的元素,优先给它们。
例:>>> li = list(range(10))

first,*mid,last = li
first
0

last
9

mid
[1, 2, 3, 4, 5, 6, 7, 8]

实现函数isdigit, 判断字符串里是否只包含数字0~9
def isdigit(string):
“”"
判断字符串只包含数字
:param string:
:return:
“”"
str = “123456789”
print(str.isdigit())
3、leetcode 5题 最长回文子串
给定一个字符串 s,找到 s 中最长的回文子串。你可以假设 s 的最大长度为 1000。
示例:
输入: “babad”
输出: “bab”
输入: “cbbd”
输出: “bb”
class Solution:
def longestPalindrome(self, s):
“”"
:type s: str
:rtype: str
“”"
dic={}
for i in range(len(s)):
for j in range(len(s)):
if s[j:i:-1]==s[i:j:]:
dic[i]=j-i
k=list(dic.keys())[list(dic.values()).index(max(dic.values()))]
v=max(dic.values())
return s[k:v+k+1:]

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值