练习题:
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
0last
9mid
[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:]