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

深圳自助网站建设费用桂平网络推广

深圳自助网站建设费用,桂平网络推广,wordpress get_terms 排序,四川省建设执业注册中心网站记录了初步解题思路 以及本地实现代码;并不一定为最优 也希望大家能一起探讨 一起进步 目录 2/17 1287. 有序数组中出现次数超过25%的元素2/18 2080. 区间内查询数字的频率2/19 624. 数组列表中的最大距离2/20 2595. 奇偶位数2/21 2209. 用地毯覆盖后的最少白色砖块…

记录了初步解题思路 以及本地实现代码;并不一定为最优 也希望大家能一起探讨 一起进步


目录

      • 2/17 1287. 有序数组中出现次数超过25%的元素
      • 2/18 2080. 区间内查询数字的频率
      • 2/19 624. 数组列表中的最大距离
      • 2/20 2595. 奇偶位数
      • 2/21 2209. 用地毯覆盖后的最少白色砖块
      • 2/22 2506. 统计相似字符串对的数目
      • 2/23 1206. 设计跳表


2/17 1287. 有序数组中出现次数超过25%的元素

存在这个元素至少出现num次 那么这个元素必定会出现在位置0,num,2*num…处
找到这些位置 寻找该位置的值出现次数

def findSpecialInteger(arr):""":type arr: List[int]:rtype: int"""import bisectn=len(arr)num=n//4+1for i in range(0,n,num):if bisect.bisect_right(arr, arr[i])-bisect.bisect_left(arr, arr[i])>=num:return arr[i]return -1

2/18 2080. 区间内查询数字的频率

使用一个map m[value]存放数值x出现的位置
求取m[value]中有多少个位置在[left,right]内
分别求0left,0right内位置个数 相减即可

from collections import defaultdict
class RangeFreqQuery(object):def __init__(self, arr):""":type arr: List[int]"""self.m = defaultdict(list)for i,v in enumerate(arr):self.m[v].append(i)def query(self, left, right, value):""":type left: int:type right: int:type value: int:rtype: int"""li = self.m[value]if len(li)==0:return 0if li[0]>right or li[-1]<left:return 0ansl,ansr=0,0if left<=li[0]:ansl = 0else:l,r = 0,len(li)while l<=r:mid = l+(r-l)//2if li[mid]==left:l = midbreakelif li[mid]>left:r = mid-1else:l = mid+1ansl = lif right>=li[-1]:ansr = len(li)-1else:l,r = 0,len(li)while l<=r:mid = l+(r-l)//2if li[mid]==right:r = midbreakelif li[mid]>right:r = mid-1else:l = mid+1ansr = rif ansr<ansl:return 0return ansr-ansl+1

2/19 624. 数组列表中的最大距离

遍历每个数组 记录最小值 最大值

def maxDistance(arrays):""":type arrays: List[List[int]]:rtype: int"""mi,ma=arrays[0][0],arrays[0][-1]ans = 0for i in range(1,len(arrays)):curmi,curma=arrays[i][0],arrays[i][-1]ans=max(ans,abs(ma-curmi),abs(curma-mi))mi=min(mi,curmi)ma=max(ma,curma)return ans

2/20 2595. 奇偶位数

依次判断当前最低位是否为一 判断好后每次除以2

def evenOddBit(n):""":type n: int:rtype: List[int]"""cur = 0even,odd=0,0while n:if n%2==1:if cur%2:odd+=1else:even+=1cur+=1n//=2return [even,odd]

2/21 2209. 用地毯覆盖后的最少白色砖块

dp[i][j]表示前i个砖用了j个地毯后最少的白色砖块

def minimumWhiteTiles(floor, numCarpets, carpetLen):""":type floor: str:type numCarpets: int:type carpetLen: int:rtype: int"""n=len(floor)dp = [[float("inf")] * (numCarpets+1) for _ in range(n+1)]for j in range(numCarpets+1):dp[0][j]=0for i in range(1,n+1):dp[i][0] = dp[i-1][0]+(1 if floor[i-1]=='1' else 0)for i in range(1,n+1):for j in range(1,numCarpets+1):dp[i][j]=dp[i-1][j]+(1 if floor[i-1]=='1' else 0)dp[i][j]=min(dp[i][j],dp[max(0,i-carpetLen)][j-1])return dp[n][numCarpets]

2/22 2506. 统计相似字符串对的数目

使用26位0,1 记录组成字符串的字母出现情况
计算相同字母的字符串个数能够组成的对数

def similarPairs(words):""":type words: List[str]:rtype: int"""tag={}for w in words:cur = 0for c in w:cur |= (1<<(ord(c)-ord('a')))tag[cur] = tag.get(cur,0)+1ans = 0for v in tag.values():ans += v*(v-1)//2return ans

2/23 1206. 设计跳表

参考 https://leetcode.cn/problems/design-skiplist/solution/she-ji-tiao-biao-by-leetcode-solution-e8yh/
将每个数字看作一个节点 节点最多有MAX_LEVAL层
如果对于某一层 该节点存在 则该位置指向下一个存在的节点
random_level 随机决定该节点层数


import random
MAX_LEVAL = 32
PRO = 0.25
def random_level():lv = 1while lv<MAX_LEVAL and random.random()<PRO:lv+=1return lvclass Node:__slots__ = ['val','forward']def __init__(self,val,maxlev=MAX_LEVAL):self.val = valself.forward = [None]*maxlevclass Skiplist(object):def __init__(self):self.head = Node(-1)self.level = 0def search(self, target):""":type target: int:rtype: bool"""cur = self.headfor i in range(self.level-1,-1,-1):while cur.forward[i] and cur.forward[i].val<target:cur = cur.forward[i]cur = cur.forward[0]if cur and cur.val==target:return Truereturn Falsedef add(self, num):""":type num: int:rtype: None"""new = [self.head]*MAX_LEVALcur = self.headfor i in range(self.level-1,-1,-1):while cur.forward[i] and cur.forward[i].val<num:cur = cur.forward[i]new[i] = curlv = random_level()self.level = max(self.level,lv)newnode = Node(num,lv)for i in range(lv):newnode.forward[i] = new[i].forward[i]new[i].forward[i] = newnodedef erase(self, num):""":type num: int:rtype: bool"""new = [self.head]*MAX_LEVALcur = self.headfor i in range(self.level-1,-1,-1):while cur.forward[i] and cur.forward[i].val<num:cur = cur.forward[i]new[i] = curcur = cur.forward[0]if not cur or cur.val!=num:return Falsefor i in range(self.level):if new[i].forward[i]!=cur:breaknew[i].forward[i] = cur.forward[i]while self.level>1 and not self.head.forward[self.level-1]:self.level-=1return True

http://www.dtcms.com/wzjs/412333.html

相关文章:

  • 网站建设优点百度风云排行榜官网
  • linux可以做网站开发吗全网热搜关键词排行榜
  • 陕西网站建设企业苏州网站建设公司
  • 手机网站导航菜单源码焦作网络推广哪家好
  • 外贸行业网站建设公司排名低价刷赞网站推广
  • 自己的网站源代码一片空白网站怎么优化推广
  • 温州网站优化排名推广汕头网站建设推广
  • wordpress the_tags()seo黑帽培训骗局
  • wordpress判断seo技术培训中心
  • 可以提升自己的网站今日头条新闻视频
  • 拓之朴 做网站多少钱武汉seo网站优化技巧
  • 凡客衬衫品牌介绍搜索引擎优化是什么意思
  • 建设银行网站建设情况白帽seo公司
  • 网站广告劫持怎么做网站收录查询工具
  • 门户网站系统建设方案沈阳市网站
  • 不成立公司怎么做企业网站搜索引擎怎么做
  • 网站做交叉连接引流推广效果好的app
  • php网站怎么搭建环境配置营销技巧和营销方法视频
  • 百万网站建设报价百度优化大师
  • 建设外贸公司网站企业网络宣传推广方案
  • 品牌设计的英文百度seo关键词优化方案
  • 微信公众号定制开发seo中介平台
  • 打代码怎么做网站如何申请域名
  • 哪个网站找做软件seo服务是什么意思
  • 南漳网站设计网站建设定制
  • 设计网站横幅业务推广方式
  • wordpress建站落后吗百度客服电话24小时客服电话
  • 徐州市中宇建设工程有限公司网站引流推广是什么意思
  • html5手机网站开发视频深圳优化公司高粱seo较
  • 网站制作的评价指标必应搜索引擎入口