每日一练 — 2022.01.16


一,最接近的三数之和

1,程序简介

  • 给定一个包括 n 个整数的数组 nums 和 一个目标值 target。找出 nums 中的三个整数,使得它们的和与 target 最接近。
  • 返回这三个数的和。
  • 假定每组输入只存在唯一答案。

示例:

  • 输入:nums = [-1,2,1,-4], target = 1
  • 输出:2
  • 解释:与 target 最接近的和是 2 (-1 + 2 + 1 = 2) 。

提示:

  • 3 < = n u m s . l e n g t h < = 1 0 3 3 <= nums.length <= 10^3 3<=nums.length<=103
  • − 1 0 3 < = n u m s [ i ] < = 1 0 3 -10^3 <= nums[i] <= 10^3 103<=nums[i]<=103
  • − 1 0 4 < = t a r g e t < = 1 0 4 -10^4 <= target <= 10^4 104<=target<=104

2,程序代码

# -*- coding: utf-8 -*-
"""
Created on Sat Jan 15 19:46:46 2022
Function: 最接近的三数之和
@author: 小梁aixj
"""
from typing import List
class Solution:
    def threeSumClosest(self, nums: List[int], target: int) -> int:
        nums.sort()
        cur = 0
        closest = nums[0] + nums[1] + nums[2]
        while cur < len(nums) - 2:
            left = cur + 1
            right = len(nums) - 1
            while left < right:
                n = nums[cur] + nums[left] + nums[right]
                if abs(target - n) < abs(target - closest):
                    closest = n
                if n == target:
                    break
                elif n > target:
                    t = right - 1
                    while (t > left and nums[t] == nums[right]):
                        t -= 1
                    right = t
                else:
                    t = left + 1
                    while (t < right and nums[t] == nums[left]):
                        t += 1
                    left = t
            t = cur + 1
            while (t < len(nums) and nums[t] == nums[cur]):
                t += 1
            cur = t
        return closest
# %%
s = Solution()
print(s.threeSumClosest(nums = [-1,2,1,-4], target = 1))

3,运行结果

在这里插入图片描述

二,螺旋矩阵 II

1,程序简介

  • 给你一个正整数 n ,生成一个包含 1 到 n2 所有元素,且元素按顺时针顺序螺旋排列的 n x n 正方形矩阵 matrix 。

示例 1:

  • 输入:n = 3
  • 输出:[[1,2,3],[8,9,4],[7,6,5]]

示例 2:

  • 输入:n = 1
  • 输出:[[1]]

提示

  • 1 <= n <= 20

2,程序代码

# -*- coding: utf-8 -*-
"""
Created on Sat Jan 15 19:48:02 2022
Function: 螺旋矩阵 II
@author: 小梁aixj
"""
class Solution(object):
    def generateMatrix(self, n):
        """
        :type n: int
        :rtype: List[List[int]]
        """
        res = [[0] * n for _ in range(n)]
        pos = [0, 0]
        move = (0, 1)
        for index in range(1, n * n + 1):
            res[pos[0]][pos[1]] = index
            if res[(pos[0] + move[0]) % n][(pos[1] + move[1]) % n] > 0:
                move = (move[1], -1 * move[0])
            pos[0] = pos[0] + move[0]
            pos[1] = pos[1] + move[1]
        return res
if __name__ == '__main__':
    s = Solution()
    print (s.generateMatrix(3))

3,运行结果

在这里插入图片描述

三,将一个列表中字典字段相同的元素合并并且值相加

1,程序简介

  • 如下两个列表,需要将oldList转化为newList,去掉相同字段的字典,并且去掉的参数里面的值要相加 oldList = [{‘0-0’: 0, ‘0-1’: 0, ‘0-2’: 0, ‘0-3’: 1972}, {‘3-3’: 203, ‘3-2’: 0, ‘3-1’: 0, ‘3-0’: 0}, {‘0-0’: 0, ‘0-1’: 0, ‘0-2’: 0, ‘0-3’: 1450}, {‘3-3’: 203, ‘3-2’: 0, ‘3-1’: 0, ‘3-0’: 0}, {‘0-0’: 0, ‘0-1’: 0, ‘0-2’: 0, ‘0-3’: 1334}]
  • newList = [{‘0-0’: 0, ‘0-1’: 0, ‘0-2’: 0, ‘0-3’: 4756}, {‘3-3’: 406, ‘3-2’: 0, ‘3-1’: 0, ‘3-0’: 0}]

2,程序代码

# -*- coding: utf-8 -*-
"""
Created on Sat Jan 15 19:48:23 2022
Function: 将一个列表中字典字段相同的元素合并并且值相加
@author: 小梁aixj
"""
import operator
oldList = [{'0-0': 0, '0-1': 0, '0-2': 0, '0-3': 1972},
           {'3-3': 203, '3-2': 0, '3-1': 0, '3-0': 0},
           {'0-0': 0, '0-1': 0, '0-2': 0, '0-3': 1450},
           {'3-3': 203, '3-2': 0, '3-1': 0, '3-0': 0},
           {'0-0': 0, '0-1': 0, '0-2': 0, '0-3': 1334}]
newList = []
newList.append(oldList[0])
for t in range(1,len(oldList)):
    for li in newList:
        if operator.eq(li.keys(), oldList[t].keys()):
            for key in li.keys():
                li[key] += oldList[t][key]
            break
        elif operator.eq(li,newList[-1]):
            newList.append(oldList[t])
            break
print(newList)

#输出:[{'0-0': 0, '0-1': 0, '0-2': 0, '0-3': 4756}, {'3-3': 406, '3-2': 0, '3-1': 0, '3-0': 0}]

3,运行结果

在这里插入图片描述

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 2
    评论
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

梁辰兴

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值