leetcode day20 Maximum Average Subarray

题目描述:给定K,求出array里面k大小的子数组最大平均值
题目思路:两种方法:
1、给另一个数组diff_array, 计算每个元素i与i-k的差,然后计算这个数组的最大连续数组值,再与原数组的前k项之和加起来则为最大的和。

class Solution:
    def findMaxAverage(self, nums: List[int], k: int) -> float:
        diff_array = []
        sum_1 = 0
        for w in range(k):
            sum_1 += nums[w]
        for i in range(k, len(nums)):
            diff_array.append(nums[i] - nums[i-k])
        diff_cur = 0
        diff_max = 0
        for j in range(len(diff_array)):
            diff_cur +=diff_array[j]
            if diff_max <diff_cur:
                diff_max = diff_cur
        return (diff_max + sum_1)/k

2、直接计算每个k个元素的子数组的和,进行比较和返回
没写这个代码,我觉得有点傻逼就没做

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
牙科就诊管理系统利用当下成熟完善的SSM框架,使用跨平台的可开发大型商业网站的Java语言,以及最受欢迎的RDBMS应用软件之一的Mysql数据库进行程序开发。实现了用户在线查看数据。管理员管理病例管理、字典管理、公告管理、药单管理、药品管理、药品收藏管理、药品评价管理、药品订单管理、牙医管理、牙医收藏管理、牙医评价管理、牙医挂号管理、用户管理、管理员管理等功能。牙科就诊管理系统的开发根据操作人员需要设计的界面简洁美观,在功能模块布局上跟同类型网站保持一致,程序在实现基本要求功能时,也为数据信息面临的安全问题提供了一些实用的解决方案。可以说该程序在帮助管理者高效率地处理工作事务的同时,也实现了数据信息的整体化,规范化与自动化。 管理员在后台主要管理病例管理、字典管理、公告管理、药单管理、药品管理、药品收藏管理、药品评价管理、药品订单管理、牙医管理、牙医收藏管理、牙医评价管理、牙医挂号管理、用户管理、管理员管理等。 牙医列表页面,此页面提供给管理员的功能有:查看牙医、新增牙医、修改牙医、删除牙医等。公告信息管理页面提供的功能操作有:新增公告,修改公告,删除公告操作。公告类型管理页面显示所有公告类型,在此页面既可以让管理员添加新的公告信息类型,也能对已有的公告类型信息执行编辑更新,失效的公告类型信息也能让管理员快速删除。药品管理页面,此页面提供给管理员的功能有:新增药品,修改药品,删除药品。药品类型管理页面,此页面提供给管理员的功能有:新增药品类型,修改药品类型,删除药品类型。
LeetCode 上关于空格替换的问题,通常是要求将一个字符串中的空格替换为 %20。这个问题可以用多种方法来解决,下面介绍两种常见的方法。 方法一:使用额外的空间 这种方法需要额外的空间来存储替换后的字符串。具体步骤如下: 1. 遍历字符串,计算空格的数量,并计算替换后的字符串长度。 2. 创建一个新的字符数组,长度为替换后的字符串长度,依次将原字符串中每个非空格字符复制到新数组中,将每个空格替换为 %20。 3. 将新数组转换为字符串并返回。 Java 代码如下: ``` public String replaceSpace(String s) { int count = 0; for (int i = 0; i < s.length(); i++) { if (s.charAt(i) == ' ') { count++; } } int length = s.length() + count * 2; char[] array = new char[length]; int index = 0; for (int i = 0; i < s.length(); i++) { char c = s.charAt(i); if (c == ' ') { array[index++] = '%'; array[index++] = '2'; array[index++] = '0'; } else { array[index++] = c; } } return new String(array); } ``` 方法二:不使用额外空间 这种方法不需要额外的空间,可以在原字符串上进行替换。具体步骤如下: 1. 遍历字符串,计算空格的数量,并计算替换后的字符串长度。 2. 从后往前遍历字符串,依次将原字符串中每个非空格字符复制到新的位置,将每个空格替换为 %20。 3. 在原字符串中替换后面的空格为 %20,返回结果。 Java 代码如下: ``` public String replaceSpace(String s) { int count = 0; for (int i = 0; i < s.length(); i++) { if (s.charAt(i) == ' ') { count++; } } int length = s.length() + count * 2; char[] array = s.toCharArray(); int index = length - 1; for (int i = s.length() - 1; i >= 0; i--) { char c = array[i]; if (c == ' ') { array[index--] = '0'; array[index--] = '2'; array[index--] = '%'; } else { array[index--] = c; } } return new String(array, 0, length); } ``` 以上两种方法的时间复杂度都是 O(n),其中 n 是字符串的长度。方法一需要额外的空间,空间复杂度是 O(n),而方法二不需要额外的空间,空间复杂度是 O(1)。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值