11.9 至 11.17 四道典型题记录: Counter 弹出 | map函数 | 子集求取 | 有序字符桶分装

news2025/8/3 8:51:16

11.9 至 11.17 四道典型题记录: Counter 弹出 | map函数 | 子集求取 | 有序字符桶分装

   昨天休息的时候一直在想应该学习哪种语言,我想这也是好多人发愁无法下手的原因之一,今年找工作的时候发现更多的研究岗位需要的是 C 语言 或 C++ 语言,而对于一些大型互联网企业则更喜欢 Java 语言,对于我而言,我更想做一些深度学习相关的工作,单纯地觉着这个行业有意思,能够支持我更长久的学习下去,虽然 搞电路和硬件设备的走得更稳定长久,不过对于我而言,我更相信学习新的、有趣的、更能激发自我动力的学科,其实没有那么多好犹豫的,想做什么就赶紧去做,不要想那么多,担忧焦虑最咩意思了!我现在就想学 py3 那就好好学,算法、计组、网络、操作系统 都会跟上脚步系统学习一下。不想了,学起来。
  本节主要是 关于py3的几个函数的使用以及个人认为非常不错的几道题的记录,一定要总结一下,就当复习了。
部分代码借鉴他人,提前说一声,这并不都是我自己码出来的。~~

791. 自定义字符串排序 (Counter 弹出)

题目链接:791. 自定义字符串排序
题目大意:给定两个字符串 order 和 s 。order 的所有字母都是 唯一 的,并且以前按照一些自定义的顺序排序。
对 s 的字符进行置换,使其与排序的 order 相匹配。更具体地说,如果在 order 中的字符 x 出现字符 y 之前,那么在排列后的字符串中, x 也应该出现在 y 之前。
返回 满足这个性质的 s 的任意一种排列 。

例如:

输入: order = "cba", s = "abcd"
输出: "cbad"
解释: 
“a”、“b”、“c”是按顺序出现的,所以“a”、“b”、“c”的顺序应该是“c”、“b”、“a”。
因为“d”不是按顺序出现的,所以它可以在返回的字符串中的任何位置。“dcba”、“cdba”、“cbda”也是有效的输出。


输入: order = "cbafg", s = "abcd"
输出: "cbad"
  • 解题思路:与 6230. 长度为 K 子数组中的最大和 的使用思路一样,需要灵活地将存储的数组进行存在元素的判断。
  • 时间复杂度: O ( M + N ) O(M+N) O(M+N) ,其中 M 和 N 分别是字符串 order 和 s 的长度。
  • 空间复杂度: O ( M ) O(M) O(M)
class Solution:
    def customSortString(self, order: str, s: str) -> str:
        cnt = collections.Counter(s)
        ans = ""
        for ch in order:
            if ch in s:
                ans += ch *cnt[ch]
                cnt.pop(ch)
        tmp = ""
        for ch in s:
            if ch not in ans:
                tmp += ch
        # print(ans,tmp)
        return ans+tmp

764. 最大加号标志 map函数(灵活运用 dmap函数)

题目链接:764. 最大加号标志 map函数
题目大意:
在一个 n x n 的矩阵 grid 中,除了在数组 mines 中给出的元素为 0,其他每个元素都为 1。mines[i] = [xi, yi]表示 grid[xi][yi] == 0

返回 grid 中包含 1 的最大的 轴对齐 加号标志的阶数 。如果未找到加号标志,则返回 0 。

一个 k 阶由 1 组成的 “轴对称”加号标志 具有中心网格 grid[r][c] == 1 ,以及4个从中心向上、向下、向左、向右延伸,长度为 k-1,由 1 组成的臂。注意,只有加号标志的所有网格要求为 1 ,别的网格可能为 0 也可能为 1 。

例如:
在这里插入图片描述

输入: n = 5, mines = [[4, 2]]
输出: 2
解释: 在上面的网格中,最大加号标志的阶只能是2。一个标志已在图中标出。

输入: n = 1, mines = [[0, 0]]
输出: 0
解释: 没有加号标志,返回 0
  • 解题思路:遍历 题目,使用动态数组继续每个点的数据记录,进行四次for循环记录满足要求的1的最小个数。需要自左向右,自右向左、自上而下以及自下而上的四次遍历,确定最小的 十字。代码中用到两次 map,非常地有趣,简单说一下:
    (1)anned = set(map(tuple,mines)) 将mines的内容转换为元素 tuple 之后使用set()函数进行去重操作 ,map 在这里可以充当数据类型转换的作用;
    (2) max(map(max,dp)) map()的存在让此语句更容易梳理一些,其实可以写成max([max(dp[i,:]) for i in range(len(dp))])
  • 时间复杂度: O ( N 2 ) O(N^2) O(N2) ,N为矩阵的行数或列数
  • 空间复杂度: O ( N 2 ) O(N^2) O(N2)
class Solution:
    def orderOfLargestPlusSign(self, n: int, mines: List[List[int]]) -> int:
        # map 函数 非常值得学习!!!
        dp = [[n]*n for _ in range(n)]
        banned = set(map(tuple,mines))
        # print(banned)
        for i in range(n):
            # left
            cnt = 0
            for j in range(n):
                cnt = 0 if (i,j) in banned else cnt+1
                dp[i][j] = min(dp[i][j],cnt)
            # right
            cnt = 0
            for j in range(n-1,-1,-1):
                cnt = 0 if (i,j) in banned else cnt+1
                dp[i][j] = min(dp[i][j],cnt)
        for j in range(n):
            # up
            cnt = 0
            for i in range(n):
                cnt = 0 if (i,j) in banned else cnt+1
                dp[i][j] = min(dp[i][j],cnt) 
            # down
            cnt=0
            for i in range(n-1,-1,-1):
                cnt = 0 if (i,j) in banned else cnt+1
                dp[i][j] = min(dp[i][j],cnt)
        return max(map(max,dp))

805. 数组的均值分割 子集求取(map巧用非常好地一个用法 值得学习!)

题目链接:805. 数组的均值分割 子集求取
题目大意:给定你一个整数数组 nums
我们要将 nums 数组中的每个元素移动到 A 数组 或者 B 数组中,
使得 A 数组和 B 数组不为空,并且 average(A) == average(B)
如果可以完成则返回true , 否则返回 false 。
注意:对于数组 arr , average(arr) 是 arr 的所有元素的和除以 arr 长度。

输入: nums = [1,2,3,4,5,6,7,8]
输出: true
解释: 我们可以将数组分割为 [1,4,5,8][2,3,6,7], 他们的平均值都是4.5。

输入: nums = [3,1]
输出: false
  • 解题思路:位运算获取子数组和 思路如下:
    • 对于 nums = [1,2], i 从 1到3
    • i = 01 则为 nums[0] = 1
    • i= 10 则为 nums[1] = 2
    • i= 11 则为 nums[0]+nums[1] = 3。
  • 时间复杂度: O ( n × 2 n 2 ) O(n \times 2^{\frac{n}{2}}) O(n×22n),n为数组长度
  • 空间复杂度: O ( n × 2 n 2 ) O(n \times 2^{\frac{n}{2}}) O(n×22n)
class Solution:
    def splitArraySameAverage(self, nums: List[int]) -> bool:
        # 折半查找法
        n = len(nums)
        if n==1: return False
        s = sum(nums)
        for i in range(n):
            nums[i] = nums[i]*n-s 
        m = n//2
        # print(1<<m,m<<1)
        left = set()
        for i in range(1,1<<m):
            # i>>j&1 把 i 算术右移 j 位,然后检测最低位是否为1
            tot = sum(x for j,x in enumerate(nums[:m]) if i>>j&1)
            if tot==0: return True
            left.add(tot)
        rsum = sum(nums[m:])
        for i in range(1,1<<(n-m)):
            tot = sum(x for j,x in enumerate(nums[m:]) if i>>j&1)
            if tot==0 or (rsum != tot and -tot in left):
                return True
        return False

792. 匹配子序列的单词数(有序字符桶分装)

题目链接:792. 匹配子序列的单词数
题目大意:
给定字符串 s 和字符串数组 words, 返回 words[i] 中是s的子序列的单词个数 。
字符串的 子序列 是从原始字符串中生成的新字符串,可以从中删去一些字符(可以是none),而不改变其余字符的相对顺序。
例如, “ace” 是 “abcde” 的子序列。

输入: s = "abcde", words = ["a","bb","acd","ace"]
输出: 3
解释: 有三个是 s 的子序列的单词: "a", "acd", "ace"。

输入: s = "dsahjpjauf", words = ["ahjpjau","ja","ahbwzgqnuk","tnmlanowax"]
输出: 2
  • 解题思路:细细品味,这道题 太 tm 棒了,这个 真滴香。

  • 时间复杂度: O ( n + ∑ i = 0 m − 1 ∣ w i ∣ ) O(n + \sum_{i=0}^{m-1} |w_i|) O(n+i=0m1wi),n和m分别为s和words的长度, O ( w i ) O(w_i) O(wi)为words[i]的长度。

  • 空间复杂度: O ( m ) O(m) O(m)

      # 时间复杂度 
      # 空间复杂度 O(m)。其中 n和m分别为s和words的长度,而 |w_i| words[i] 的长度。
    
class Solution:
    def numMatchingSubseq(self, s: str, words: List[str]) -> int:
        d = collections.defaultdict(deque)
        ans = 0
        for i,w in enumerate(words):
            d[w[0]].append((i,0))
        for ch in s:
            for _  in range(len(d[ch])):
                i,j = d[ch].popleft()
                j += 1
                if j == len(words[i]):
                    ans += 1
                else:
                    d[words[i][j]].append((i,j))
        return ans

总结

   努力 奋斗!最近学一下 粤语 背一下 张国荣哥哥的歌曲,感觉 他的歌 好棒好棒,好有力量!像“默默向上游”的”现实欺弄不担忧,我要与他决斗,挺着胸对抗命运,努力握实我拳头“、“我愿那苦痛变力量,默默忍泪向上游”,让我感觉到一种前所未有的力量在里面,和 迈克杰克逊的洒脱率真不一样,张国荣哥哥有一种不服输、抗争、顽强不屈的精神在其中,他要把事情做好、做到极致,他爱自己的事业、爱自己的人生,要全身心地去做、去努力,正如歌曲中的“求能用心”、“求能用功”、“求能做个好鼓手”。我要学习,要继续努力,“努力不会有极限”,“若遇失败再重头”。这算法不好学,那就更用心、更用功,我还就不信有学不会的!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/15902.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

RocketMQ的事务消息和改造

什么是 rmq分布式事务消息&#xff1f; Apache RocketMQ在4.3.0版中已经支持分布式事务消息&#xff0c;这里RocketMQ采用了2PC的思想来实现了提交事务消息&#xff0c;同时增加一个补偿逻辑来处理二阶段超时或者失败的消息&#xff0c;如下图所示。 事务消息解决什么问题&…

Java学习笔记 --- 多线程

一、线程相关概念 程序 程序是为完成特定任务&#xff0c;用某种语言编写的一组指令的集合。简单的说就是我们写的代码 进程 1、进程是指运行中的程序&#xff0c;比如我们使用QQ&#xff0c;就启动了一个进程&#xff0c;操作系统就会为该进程分配内存空间。当我们使用迅雷&…

程序控制结构

程序控制结构程序流程控制介绍顺序控制分支控制if-else单分支案例&#xff1a;编写一个程序&#xff0c;可以输入人的年龄&#xff0c;如果该同志的年龄大于等于 18 岁, 则输出 "你年龄大于 18,要对自己的行为负责,送入监狱"。双分支案例&#xff1a;编写一个程序&am…

关于Python函数的几点说明

关于Python函数的几点说明 本文介绍Python函数返回值、调用函数加括号和不加括号有什么区别、冒号后面省略号&#xff08;...&#xff09;和 pass等说明。 一、为什么函数意外返回“None” 初学者可能遇到这种情况&#xff0c;定义的函数意外返回“None”&#xff0c;例如&a…

Qt error: fatal error: Killed signal terminated program cc1plus

Qt error: fatal error: Killed signal terminated program cc1plus 文章目录Qt error: fatal error: Killed signal terminated program cc1plus摘要1 出现问题原因2 解决方法虚拟机物理机增加SWAP交换空间关键字&#xff1a; qt、 fatal、 error、 cc1plus、 Killed signal …

K8S实战 - 如何在kubernetes中安装软件

如何在kubernetes中安装软件 1、编写脚本安装 通过编写yaml文件&#xff0c;执行kubectl apply -f 可以安装软件 编写yaml的时候注意事项&#xff1a; pod的类型&#xff08;deployment、statefulset等&#xff09;端口的定义&#xff08;service&#xff09;配置文件的定义…

艾美捷Cholesterol胆固醇功效和参数说明

胆固醇又称胆甾醇。一种环戊烷多氢菲的衍生物。其溶解性与脂肪类似&#xff0c;不溶于水&#xff0c;易溶于乙-醚、氯-仿等溶剂。胆固醇是动物组织细胞所不可缺少的重要物质&#xff0c;它不仅参与形成细胞膜&#xff0c;而且是合成胆汁酸&#xff0c;维生素D以及甾体激素的原料…

[附源码]计算机毕业设计JAVA公益劳动招募管理系统

[附源码]计算机毕业设计JAVA公益劳动招募管理系统 项目运行 环境配置&#xff1a; Jdk1.8 Tomcat7.0 Mysql HBuilderX&#xff08;Webstorm也行&#xff09; Eclispe&#xff08;IntelliJ IDEA,Eclispe,MyEclispe,Sts都支持&#xff09;。 项目技术&#xff1a; SSM my…

漏洞深度分析|Apache MINA SSHD反序列化漏洞

项目介绍 Apache MINA SSHD 是一个 100% 纯 java 库&#xff0c;支持客户端和服务器端的 SSH 协议。它的目的不是要替代 Unix 操作系统中的 SSH 客户端或 SSH 服务器&#xff0c;而是为需要 SSH 支持的基于 Java 的应用程序提供支持。 该库可以利用多个 I/O 后端&#xff1a; …

最小二乘法在ISP CCM标定中的简介

一、基础知识 假设我们有16幅名人脸部灰度图像&#xff0c;我们是否可以找到16幅脸部图像的线性组合&#xff0c;使得其线性组合最接近于目标脸部图像呢&#xff1f; 名人库我们知道灰度图像可以用矩阵表示。假设有如下灰度图。 我们可以用矩阵表示为&#xff1a; 我们也可以用…

Python机器学习16——相关向量机(RVM)

本系列基本不讲数学原理&#xff0c;只从代码角度去让读者们利用最简洁的Python代码实现机器学习方法。 背景介绍 学机器学习的应该都知道支持向量机&#xff08;SVM&#xff09;&#xff0c;这个方法在深度学习兴起之前算是很热门的分类方法&#xff0c;在机器学习里面&#…

Go: 通过Fiber构建微服务

文章目录简介1. 微服务2. Fiber&#xff1f;Fiber集成及使用1.安装fiber2. 简单使用3.简单实例小结简介 1. 微服务 微服务或微服务架构是一种体系结构风格&#xff0c;可以将应用程序构建成一个服务的集合&#xff1a; Maintainable 可维修Testable 可测试的Loosely coupled…

毫米波雷达基础知识系列——FFT

毫米波雷达基础知识系列——FFT及DSP优化实现FFT来源FFT为什么快FFT的种类基2FFT推导FFT来源 FFT来源于DFT离散傅里叶变换&#xff0c;DFT的计算公式为&#xff1a; X(k)∑n0N−1x(n)WNknX(k) \sum_{n0}^{N-1} x(n)W_{N}^{kn} X(k)n0∑N−1​x(n)WNkn​ 为什么不直接用DFT计算…

【 java 常用类】日期相关 API 操作

&#x1f4cb; 个人简介 &#x1f496; 作者简介&#xff1a;大家好&#xff0c;我是阿牛&#xff0c;全栈领域优质创作者。&#x1f61c;&#x1f4dd; 个人主页&#xff1a;馆主阿牛&#x1f525;&#x1f389; 支持我&#xff1a;点赞&#x1f44d;收藏⭐️留言&#x1f4d…

ZYNQ之FPGA学习----MMCM/PLL IP核使用实验

1 MMCM/PLL IP核介绍 PLL 的英文全称是 Phase Locked Loop&#xff0c;即锁相环&#xff0c;是一种反馈控制电路。PLL 对时钟网络进行系统级的时钟管理和偏移控制&#xff0c;具有时钟倍频、分频、相位偏移和可编程占空比的功能 Xilinx 7 系列器件中的时钟资源包含了时钟管理…

Kata3.0.0 x LifseaOS x 龙蜥内核三管齐下!带你体验最新的安全容器之旅

文/云原生SIG 北京时间 2022 年 10 月 10 日&#xff0c;袋鼠 RunD 安全容器&#xff08;Rust Kata runtime Dragonball VMM&#xff09;正式作为安全容器上游 Kata Container 3.0.0 release 版本的重要特性发布。 龙蜥体验包 安全容器作为龙蜥云原生重要项目&#xff0c;我…

EEG微状态预测并发fMRI动态功能连接状态

前言 静息态功能磁共振成像(rs-fMRI)测量的大脑功能连接在多个时间尺度上有所不同&#xff0c;并确定了循环的动态功能连接(dFC)状态。这些发现与不同的认知和病理状态有关&#xff0c;有可能作为疾病的生物标志物&#xff0c;但它们的神经基础仍然存在争议。在静息态EEG研究中…

docker常见问题汇总(持续更新中)

Docker pull 时报错如下&#xff1a; -bash-4.2# docker pull hub.yj.com/test/dep_client:test Error response from daemon: Get http://hub.yj.com/v2/: dial tcp: lookup hub.yj.com on 218.2.135.1:53: server misbehaving如下图&#xff1a; 原因解析&#xff1a; 本地…

【算法系列】非线性最小二乘-高斯牛顿法

系列文章目录 【算法系列】卡尔曼滤波算法 【算法系列】非线性最小二乘求解-直接求解法 【算法系列】非线性最小二乘求解-梯度下降法 【算法系列】非线性最小二乘-高斯牛顿法 文章目录 系列文章 文章目录 前言 一、牛顿法 二、高斯-牛顿法 1.由牛顿法推导 2.直接展…

深度学习入门(四十三)计算机视觉——锚框

深度学习入门&#xff08;四十三&#xff09;计算机视觉——锚框前言计算机视觉——锚框课件锚框IoU交并比赋予锚框符号使用非极大值抑制&#xff08;NMS&#xff09;输出总结教材1 生成多个锚框2 交并比&#xff08;IoU&#xff09;3 在训练数据中标注锚框3.1 将真实边界框分配…