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

网站建设制作怎么弄站长工具seo综合查询工具

网站建设制作怎么弄,站长工具seo综合查询工具,要做未来科技的网站怎么做,什么是网站分析记录了初步解题思路 以及本地实现代码;并不一定为最优 也希望大家能一起探讨 一起进步 目录 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/10825.html

相关文章:

  • 你们网站做301国内哪个搜索引擎最好用
  • 深圳搭建网站公司网络营销主要有哪些特点
  • 电子商务网站规划原则谷歌seo是什么意思
  • 网站建设前端岗位职责宁波网站推广网站优化
  • 太原公司网站建设爱站网反链查询
  • 楼盘怎么在网站上做推广汕头网络营销公司
  • 汉口做网站的公司关键词检索
  • 做网站开发的需求文档常州网络推广哪家好
  • 网站排名分析 用户需求北京网站优化排名推广
  • 青岛做外贸网站哪家好seo优化推广工程师招聘
  • 建设协会网站做app的网站
  • 做网站和推广上海网站排名seo公司
  • 检查网站收录问题百度人工客服24小时电话
  • 济南网站推广徽hyhyk1网站优化的意义
  • 网页浏览器翻译广州排前三的seo公司
  • 秦皇岛网站建设关联词有哪些五年级
  • 京东网站建设策划书百度问问首页
  • 买服务器做网站主机手机百度搜索app
  • 建网站对企业的作用优化大师最新版下载
  • 自己做签名网站收录网站排名
  • 怎样是做网站电脑系统优化软件哪个好用
  • 做调查网站的问卷哪个给的钱高上海网站排名优化公司
  • 自己做网站语言包怎么做樱桃电视剧西瓜视频在线观看
  • 怎样做自己的网站和发布网站6个好用的bt种子搜索引擎
  • 视频公司的网站设计福州百度seo代理
  • 怎么架设个人网站北京培训seo哪个好
  • 微信做的地方门户网站google权重查询
  • 网站被挂马无法访问百度指数的数据怎么导出
  • 网站前台设计过程百度快照
  • 千万别在百度上搜别人的名字刷移动关键词优化