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

h5 网站模板搜索引擎优化时营销关键词

h5 网站模板,搜索引擎优化时营销关键词,wordpress 代码压缩,php 开源企业网站Powered by:NEFU AB-IN Link 文章目录 2940. 花坛的最小改变次数题意思路代码 2940. 花坛的最小改变次数 题意 略 思路 首先需要区间查询gcd,想到st表 其次思路,固定左端点,二分右端点,找gcd与区间长度相等的右端点,个…

Powered by:NEFU AB-IN

Link

文章目录

  • 2940. 花坛的最小改变次数
    • 题意
    • 思路
    • 代码

2940. 花坛的最小改变次数

  • 题意

  • 思路

    首先需要区间查询gcd,想到st表
    其次思路,固定左端点,二分右端点,找gcd与区间长度相等的右端点,个人是这么理解的:

    • 区间长度 mid - i + 1
    • gcd
    • 区间长度随mid增大而增大,gcd随mid增大而减小或不变
    • 区间长度开始为1,gcd开始大于等于1,所以两者如果无限延伸一定有交点(可能不止一个),所以找到最右边的设为x,那么x往左的,都是gcd大于等于区间长度的,那么把这个区间放进答案数组
      在答案数组里,按右端点排序,如果两个端点可以合并,如果某个区间左端点可以小于前哥区间右端点,说明可以一起改,统计改几次即可
  • 代码

    '''
    Author: NEFU AB-IN
    Date: 2023-06-09 18:00:12
    FilePath: \LanQiao\2940\2940.py
    LastEditTime: 2023-06-09 20:09:28
    '''
    # import
    from sys import setrecursionlimit, stdin, stdout, exit
    from collections import Counter, deque
    from heapq import heapify, heappop, heappush, nlargest, nsmallest
    from bisect import bisect_left, bisect_right
    from datetime import datetime, timedelta
    from string import ascii_lowercase, ascii_uppercase
    from math import log, gcd, sqrt, fabs, ceil, floorclass sa:def __init__(self, x, y):self.x = xself.y = ydef __lt__(self, a):return self.y < a.y# Final
    N = int(2e5 + 10)
    M = 20
    INF = int(2e9)# Define
    setrecursionlimit(INF)
    input = lambda: stdin.readline().rstrip("\r\n")  # Remove when Mutiple data
    read = lambda: map(int, input().split())
    LTN = lambda x: ord(x.upper()) - 65  # A -> 0
    NTL = lambda x: ascii_uppercase[x]  # 0 -> A# —————————————————————Division line ——————————————————————
    dp = [[0] * M for _ in range(N)]
    Log = [0] * N
    a = [0] * Ndef init():for j in range(M):i = 1while i + (1 << j) - 1 <= n:if j == 0:dp[i][j] = a[i]else:dp[i][j] = gcd(dp[i][j - 1], dp[i + (1 << (j - 1))][j - 1])i += 1for i in range(2, N):Log[i] = Log[i // 2] + 1def query(l, r):k = Log[r - l + 1]return gcd(dp[l][k], dp[r - (1 << k) + 1][k])n, = read()
    a[1:] = read()ans = []
    init()for i in range(1, n + 1):l, r = i, nwhile l < r:mid = l + r + 1 >> 1if query(i, mid) >= mid - i + 1:l = midelse:r = mid - 1if query(i, l) == l - i + 1:ans.append(sa(i, l))cnt = 1
    if len(ans) == 0:print(0)
    else:ans.sort()tmp = ans[0].yfor i in ans:if i.x > tmp:cnt += 1tmp = i.yprint(cnt)
http://www.dt0577.cn/news/32479.html

相关文章:

  • 做网站的软件有哪些百度seo搜索引擎优化厂家
  • 如何创建属于个人网站seo的英文全称是什么
  • 设计logo多少钱seo平台怎么样
  • 网站登录入口大全关键词热度查询
  • 怎么做网站在线玩游戏百度推广做二级域名
  • 做自己的网站需要会编程吗今日军事新闻头条最新
  • 工商信息查询seo网站关键词优化机构
  • 关于网站开发的论文文献连云港seo优化公司
  • 泉州seo建站最彻底的手机优化软件
  • 在北京找工作哪个网站靠谱创建网站的软件
  • 上外贸网站建设网站关键词怎么写
  • 传媒视频软件下载网站北京优化网站建设
  • 金融网站建设报价方案b2b商务平台
  • 济南网站建设团队个人网页怎么制作
  • 个人做房产网站有哪些百度免费seo
  • 自己设计logo网站网络营销管理办法
  • 睢宁县建设工程招标网北京搜索优化排名公司
  • 优异网站seo优化顾问服务阿亮
  • idea怎么做网站东莞百度seo哪里强
  • 京东短网址在线生成石家庄网站seo
  • 重庆建立公司网站黑帽seo教程
  • 新加坡网站制作国际新闻界官网
  • 电商做网站正规网络教育培训机构
  • 网站设计难点短视频运营公司
  • 网站开发php和c语言区别百度关键词收费标准
  • 内蒙古工程建设网站网络营销课程论文
  • 广州越秀发布厦门seo公司到1火星
  • 海尔电子商务网站建设情况怎么做互联网营销推广
  • 个人主题网站南阳seo优化
  • cf辅助如何做代理拿网站免费做网站网站的软件