当前位置: 首页 > news >正文

网站建设公司 资讯百度信息流推广是什么意思

网站建设公司 资讯,百度信息流推广是什么意思,wordpress 主题 mnews,wordpress嵌入优酷视频前言: 哈喽大家好,前段时间在小红书和牛客上发了面试的经验贴,很多同学留言问算法的具体解法,今天就详细写个帖子回复大家。 因为csdn是写的比较详细,所以更新比较慢,大家见谅~~ 就题目而言,…

前言:

哈喽大家好,前段时间在小红书和牛客上发了面试的经验贴,很多同学留言问算法的具体解法,今天就详细写个帖子回复大家。

因为csdn是写的比较详细,所以更新比较慢,大家见谅~~

就题目而言,前两题是平时刷题常见的,第三题没有见过,需要认真思考下

最后,希望找工作的同学都能收获心仪的offer

求两个数的最大公约数

链接

这道题没有找到原题链接,找到一个近似的题目

1979. 找出数组的最大公约数 - 力扣(LeetCode)icon-default.png?t=N7T8https://leetcode.cn/problems/find-greatest-common-divisor-of-array/description/

给你一个整数数组 nums ,返回数组中最大数和最小数的 最大公约数 。

两个数的 最大公约数 是能够被两个数整除的最大正整数。

思路

辗转相除法原理:

两个整数的最大公约数等于其中较小的数和两数相除余数的最大公约数。

例如:欲求252和105的最大公约数;因为 252÷105=2...42,所以这个最大公约数也是42与105的最大公约数(42=21×2)。在这个过程中,较大的数缩小了,所以继续进行同样的计算可以不断缩小这两个数直至余数为零。这时,所剩下的还没有变成零的数就是两数的最大公约数。

我们将上述过程翻译成递归代码,得到如下代码:

class Solution:def findGCD(self, nums: List[int]) -> int:def gcd(x,y):if x>y:x,y = y,xif x==0:return yreturn gcd(y%x,x)return gcd(max(nums),min(nums))

lru缓存

请你设计并实现一个满足  LRU (最近最少使用) 缓存 约束的数据结构。

实现 LRUCache 类:

  • LRUCache(int capacity) 以 正整数 作为容量 capacity 初始化 LRU 缓存
  • int get(int key) 如果关键字 key 存在于缓存中,则返回关键字的值,否则返回 -1 。
  • void put(int key, int value) 如果关键字 key 已经存在,则变更其数据值 value ;如果不存在,则向缓存中插入该组 key-value 。如果插入操作导致关键字数量超过 capacity ,则应该 逐出 最久未使用的关键字。

函数 get 和 put 必须以 O(1) 的平均时间复杂度运行。

链接 :LRUCache. - 备战技术面试?力扣提供海量技术面试资源,帮助你高效提升编程技能,轻松拿下世界 IT 名企 Dream Offer。icon-default.png?t=N7T8https://leetcode.cn/problems/lru-cache/

思路

我这里用列表模拟队列,用字典实现缓存,设计了总容量,当前元素数等变量进行模拟

class LRUCache:def __init__(self, capacity: int):self.capacity = capacityself.cnt = 0self.queue = []self.dic = defaultdict(int)def get(self, key: int) -> int:if key not in self.dic:return -1del self.queue[self.queue.index(key)]self.queue.append(key)# print(self.queue)return self.dic[key] def put(self, key: int, value: int) -> None:if key in self.dic:del self.queue[self.queue.index(key)]self.queue.append(key)self.dic[key] = valueelif self.cnt < self.capacity:self.queue.append(key)self.dic[key] = valueself.cnt+=1else:del self.dic[self.queue[0]]del self.queue[0]self.queue.append(key)self.dic[key] = value# Your LRUCache object will be instantiated and called as such:
# obj = LRUCache(capacity)
# param_1 = obj.get(key)
# obj.put(key,value)

最长字符串链

链接:

最长字符串链icon-default.png?t=N7T8https://leetcode.cn/problems/longest-string-chain/

给出一个单词数组 words ,其中每个单词都由小写英文字母组成。

如果我们可以 不改变其他字符的顺序 ,在 wordA 的任何地方添加 恰好一个 字母使其变成 wordB ,那么我们认为 wordA 是 wordB 的 前身 。

  • 例如,"abc" 是 "abac" 的 前身 ,而 "cba" 不是 "bcad" 的 前身

词链是单词 [word_1, word_2, ..., word_k] 组成的序列,k >= 1,其中 word1 是 word2 的前身,word2 是 word3 的前身,依此类推。一个单词通常是 k == 1 的 单词链 。

从给定单词列表 words 中选择单词组成词链,返回 词链的 最长可能长度 

思路

这道题是这三道中我唯一没有见过的题,但面试中遇到没见过的题也蛮正常的,不要慌,放心做即可。

我们对每一个字符串进行查找,比如 abfd,我们检查bfd,afd,abd,abf这四个字符串在不在words数组中,如果不在就return,否则继续查找,保存最长的链条。

这道题中,我在dfs函数上加了缓存,存储一些已经计算的点,使用tuple()是因为列表无法被哈希话,所以把它转为元组。题解中有很多更好的写法,读者可以多去学习

class Solution:def longestStrChain(self, words: List[str]) -> int:global cntcnt = 0words = tuple(words)@cachedef dfs(w,words,length):if w not in words:global cntcnt = max(cnt,length)returnn = len(w)for i in range(n):temp = ww = w[0:i] + w[i+1:]dfs(w,words,length+1)w = tempfor w in words:dfs(w,words,0)return cnt



 

http://www.hkea.cn/news/980783/

相关文章:

  • 建立网站舆情分析报告范文
  • wordpress 空格 插件班级优化大师app
  • 成都有实力的网站建设网络培训心得
  • 中企高呈建设网站在百度怎么创建自己的网站
  • 女的和女的做那个视频网站怎么在网上做网络营销
  • 网站开发需要什么软件百度怎样发布作品
  • 专门做宠物食品的网站市场调研怎么做
  • 兰州网站建设q.479185700棒成年s8视频加密线路
  • 付费网站推广seo关键词排名优化怎么收费
  • 网站由那些组成google网页搜索
  • 对一个网站做性能测试谷歌paypal官网入口
  • 北京住房投资建设中心网站首页快速排名怎么做
  • 中国网站制作 第一个佛山网站优化
  • thinkphp做的教育网站微商引流推广
  • 做特卖网站手机版电商最好卖的十大产品
  • 怎样做网站平叿trinseo公司
  • 北京大兴最专业的网站建设公司如何推广一个项目
  • 网页设计最牛的网站建设宁波网站优化公司哪家好
  • 建设通查询如何做网站推广及优化
  • 城乡建设网站首页百度seo收录软件
  • 永久免费建个人网站培训网站建设
  • 如何使用jq做弹幕网站好用的磁力搜索引擎
  • 南充营销型网站建设高端品牌网站建设
  • 制作小程序和网站的公司搜狗收录提交入口网址
  • 手机站电影基础建站如何提升和优化
  • 江苏 网站备案百度贴吧官网app下载
  • 网站制作三站湖南网站seo公司
  • 简单做任务赚钱网站企业管理培训课程报名
  • 零点研究咨询集团官方网站建设相似图片在线查找
  • 网站开发需要什么软件关键词app