链接: 6233. 温度转换
签到。
class Solution:
def convertTemperature(self, c: float) -> List[float]:
return [c+273.15,c*1.80+32]
class Solution:
def subarrayLCM(self, nums: List[int], k: int) -> int:
ans = 0
n = len(nums)
q = deque()
for i in range(n):
p = nums[i]
for j in range(i,n):
p = lcm(p,nums[j])
if p == k:
# print(i,j,p)
ans += 1
elif p > k:
break
return ans
# Definition for a binary tree node.
# class TreeNode:
# def __init__(self, val=0, left=None, right=None):
# self.val = val
# self.left = left
# self.right = right
def calc(a):
t = sorted(a)
p = {x:i for i,x in enumerate(t)}
n = len(a)
ans = 0
for i in range(n):
while a[i] != t[i]:
ans += 1
j = p[a[i]]
a[i],a[j] = a[j],a[i]
return ans
class Solution:
def minimumOperations(self, root: Optional[TreeNode]) -> int:
q = deque([root])
ans = 0
while q:
nq = []
for _ in range(len(q)):
o = q.popleft()
if o.left:
q.append(o.left)
nq.append(o.left.val)
if o.right:
q.append(o.right)
nq.append(o.right.val)
if nq:
ans += calc(nq)
return ans
class Solution:
def maxPalindromes(self, s: str, k: int) -> int:
n = len(s)
if k == 1:
return n
# f = [[0]*n for _ in range(n)] # f[i][j]区间的值
f = [0]*n # 前缀答案
@cache
def is_hui(l,r):
if l == r:
return 1
if l>r:
return 1
if l+1 == r:
return int(s[l]==s[r])
return int(s[l]==s[r] and is_hui(l+1,r-1))
f[k-1] = is_hui(0,k-1)
# print(k)
for i in range(k,n):
f[i] = f[i-1]
for l in range(i-k+1,-1,-1):
if is_hui(l,i):
f[i] = max(f[i],f[l-1]+1 if l >= 0 else 1)
break
# print(f)
is_hui.cache_clear()
return f[-1]