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

芜湖集团网站建设dede小游戏php网站源码

芜湖集团网站建设,dede小游戏php网站源码,深圳网站建设知名公司,知名网站域名文章目录 题目总览题目详解找到字符串中合法的相邻数字重新安排会议得到最多空余时间I3440.重新安排会议得到最多空余时间II 第149场双周赛 题目总览 找到字符串中合法的相邻数字 重新安排会议得到最多空余时间I 重新安排会议得到最多空余时间II 变成好标题的最少代价 题目…

文章目录

  • 题目总览
  • 题目详解
    • 找到字符串中合法的相邻数字
    • 重新安排会议得到最多空余时间I
    • 3440.重新安排会议得到最多空余时间II

第149场双周赛

题目总览

找到字符串中合法的相邻数字

重新安排会议得到最多空余时间I

重新安排会议得到最多空余时间II

变成好标题的最少代价

题目详解

找到字符串中合法的相邻数字

在这里插入图片描述

思路分析:签到题,但是可以借助这个Counter来计数,然后正常遍历即可

from collections import Counter
class Solution:def findValidPair(self, s: str) -> str:st = list(s)co = Counter(st)n = len(st)ans = ""for i in range(1,n):if st[i] != st[i-1] and co[st[i]] == int(st[i]) and co[st[i-1]] == int(st[i-1]):ans = st[i-1] + st[i]break#return ansreturn ans

重新安排会议得到最多空余时间I

在这里插入图片描述
在这里插入图片描述

思路1:
思路分析:首先得将题目进行转化,计算出每段时间的空余时间,对于活动,则记空余时间为0,对于每一个k,后续使用双指针进行,定窗口滑动的时候,k+=k

class Solution:def maxFreeTime(self, eventTime: int, k: int, startTime: List[int], endTime: List[int]) -> int:# 范围会很长se = list(zip(startTime,endTime))# 已经按照开始时间的升序排序se.sort(key=lambda x: x[0])# 可以先计算出空余时间段的一个情况# 要是能够统计对于一个空余时间段的左边和右边距离下一个空余时间段的数目就好了kong = []for i,(s,e) in enumerate(se):if i == 0:kong.append(s-0)kong.append(0)continue# 计算现在的活动与上一个活动之间的空余时间kong.append(se[i][0] - se[i-1][1])kong.append(0)kong.append(eventTime - se[-1][1])# 使用双指针进行计算n = len(kong)k+=knowsum = sum(kong[0:k + 1])ans = max(0, nowsum)left, right = 0, k + 1while right < n :nowsum = nowsum - kong[left] + kong[right]left += 1right += 1ans = max(ans, nowsum)# for i in range(n-k):#     ans = max(ans,sum(kong[i:i+k+1]))# 感觉上面一直调用这个sum 会超时return ans

参考灵神的思路

思路2:
思路2是对于思路1的优化,在思路1中,我们对于有活动安排的设置为0,这样实际上,让我们的kong数组变长,显得冗余,多余的部分,让我们的滑动窗口的长度变为了2K+1
实际上,我们对于n个活动,总共会产生n+1个空余时间段,对于重新安排的最多的k个会议,实际上就是求解合并其中k+1个连续的时间段,所能够得到的最大的空闲时间

class Solution:def maxFreeTime(self, eventTime: int, k: int, startTime: List[int], endTime: List[int]) -> int:# 获得对应的空闲时间def get(i: int) -> int:if i == 0:return startTime[0]if i == n:return eventTime - endTime[-1]return startTime[i] - endTime[i - 1]n = len(startTime)ans = s = 0# 定长滑动窗口的模版for i in range(n + 1):s += get(i)if i < k:continueans = max(ans, s)s -= get(i - k)return ans

3440.重新安排会议得到最多空余时间II

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

思路分析:总体来说,还是继续使用上一题:重新安排会议得到最多空余时间I的思路框架相当于上一题的k=1,不同的是,由于上一题不能修改活动的相对顺序,只能在相邻的两个空余时间之间移动,但是这一题可以平移出相邻的空闲时间限制,那么如何考虑这种情况?我们只需记录,空闲时间rest[i]的左边和右边的最大的空闲时间,如果能够容纳下该活动,则转移过去,同时ans要加上目前的活动

from typing import Listclass Solution:def maxFreeTime(self, eventTime: int, startTime: List[int], endTime: List[int]) -> int:"""计算最大空闲时间:param eventTime: 事件的总时间:param startTime: 每个事件的开始时间列表:param endTime: 每个事件的结束时间列表:return: 最大空闲时间"""n = len(startTime)if n == 0:return 0# 计算每个间隔的空闲时间rest = [0] * (n + 1)for i in range(n + 1):if i == 0:rest[i] = startTime[0]  # 第一个事件之前的空闲时间elif i == n:rest[i] = eventTime - endTime[n - 1]  # 最后一个事件之后的空闲时间else:rest[i] = startTime[i] - endTime[i - 1]  # 事件之间的空闲时间# 计算每个间隔左边的最大空闲时间left = [0] * (n + 1)for i in range(1, n + 1):left[i] = max(left[i - 1], rest[i - 1])# 计算每个间隔右边的最大空闲时间right = [0] * (n + 1)for i in range(n - 1, -1, -1):right[i] = max(right[i + 1], rest[i + 1])# 计算最大空闲时间ans = 0for i in range(n):# 当前两个连续的空闲时间current_rest = rest[i] + rest[i + 1]# 当前活动的时间act_time = endTime[i] - startTime[i]# 如果左边或右边的最大空闲时间大于当前活动时间,则将其加入if left[i] >= act_time or right[i + 1] >= act_time:current_rest += act_time# 更新最大空闲时间ans = max(ans, current_rest)return ans
http://www.yayakq.cn/news/609136/

相关文章:

  • 网站多久备案一次吗青海建设兵团网站小院
  • 四川建设安全协会网站高端网站案例欣赏
  • 建一个公司网站费用阿里巴巴网站建设缺点
  • 可以做mv的视频网站射阳建设网站哪家好
  • 淘宝客网站搜索怎么做运营公开网是什么网站
  • 中山那些网站公司做超市促销海报哪个网站好
  • 宁波企业网站搭建图片网站建设人员组成
  • 深圳网站设计兴田德润放心网络架构图
  • 杭州便宜的手机网站建设网站怎么做一级域名跳转
  • 做学校后台网站用什么浏览器wordpress配置ftp服务器配置
  • 没有网站可以做app吗wordpress js代码编辑器
  • 雄县做网站的河北邢台地震
  • 资讯门户类网站太原网站建设团队
  • 如何做旅游网站长沙经济技术开发区人才网
  • 邯郸网站维护vps 内存影响 网站
  • 云南建设厅网站首页程序员培训机构课程
  • 酒店品牌推广方案网站头部设计优化
  • 网站建设安全措施长沙官网网站建设
  • 相亲网站认识的可以做朋友网站现在如何做推广
  • 怎样在百度建网站青岛网站建设哪个好
  • 找人帮你做ppt的网站吗做外汇上什么网站看新闻
  • 做数字艺术设计的网站桂林最新消息今天
  • 有手机网站了还要微网站吗中企动力做网站一次性付款
  • 在线教育网站开发文档建e网3d模型免费下载
  • 境外网站不备案盈利怎么判断网站是不是模板做的
  • php充值网站源码辽宁省建设工程信息网站
  • 中国站长站官网电脑搭建网站
  • 论坛网站怎么做网页图片转换成pdf文件
  • 建设工程资讯哪个网站好个人简历样本范文
  • 怎么做公司内部网站炫酷的动画网站