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

网站开发什么比较有创意怎么优化整站

网站开发什么比较有创意,怎么优化整站,个人商城网站怎么做,做网站组织架构2364.统计坏数对的数目 问题 问题分析 根据题目要求&#xff0c;(i, j) 是一个坏数对的条件是&#xff1a; i < j j - i ! nums[j] - nums[i]&#xff0c;即 nums[j] - j ! nums[i] - i 因此&#xff0c;我们可以转换问题&#xff1a;对于每个 j&#xff0c;找到所有 i &l…

2364.统计坏数对的数目

问题

在这里插入图片描述

问题分析

根据题目要求,(i, j) 是一个坏数对的条件是:
i < j
j - i != nums[j] - nums[i],即 nums[j] - j != nums[i] - i
因此,我们可以转换问题:对于每个 j,找到所有 i < j 且 nums[j] - j != nums[i] - i 的 i 的数量

思考

首先考了简单枚举:

class Solution:def countBadPairs(self, nums: List[int]) -> int:ans = 0for i in range(len(nums) - 1):for j in range(i + 1, len(nums)):if j - i != nums[j] - nums[i]:ans += 1return ans

字符串长的情况在这里插入图片描述
数据量大会导致超时

其他解法

计算 nums[i] - i 的值

首先,我们计算每个位置 i 上 nums[i] - i 的值,并存储这些值。

使用哈希表维护

使用一个哈希表来维护到当前 j 位置为止,所有 nums[i] - i (i < j)的出现次数。
遍历数组:对于每个 j,计算 nums[j] - j。
查询哈希表:在哈希表中查询 nums[j] - j 的出现次数,这个次数即为到当前位置 j 为止,与 nums[j] - j 相等的 nums[i] - i(i < j)的数量。
更新结果:坏数对的数量为 j(当前索引)减去上述查询得到的次数(即不相等的数量)。
更新哈希表:将 nums[j] - j 的出现次数加 1。

代码

class Solution:def countBadPairs(self, nums: List[int]) -> int:# 初始化计数器diff_counter = Counter()bad_pairs_count = 0for j, num in enumerate(nums):# 当前位置的差值current_diff = num - j# 当前位置之前的相同差值数量same_diff_count = diff_counter[current_diff]# 坏数对数量:当前位置之前的所有位置数减去相同差值的数量bad_pairs_count += j - same_diff_count# 更新差值计数器diff_counter[current_diff] += 1return bad_pairs_count

复杂度分析

时间复杂度:O(n),其中 n 是 nums 的长度。我们只进行了一次遍历,并且每次操作(查询和更新哈希表)的平均时间复杂度为 O(1)。
空间复杂度:O(n),最坏情况下,哈希表中需要存储 n 个不同的差值

学习

在这里插入图片描述

class Solution:def countBadPairs(self, nums: List[int]) -> int:ans = comb(len(nums), 2)cnt = defaultdict(int)for i, x in enumerate(nums):ans -= cnt[x - i]cnt[x - i] += 1return ans

时间复杂度:O(n),其中 n 是 nums 的长度。
空间复杂度:O(n)。

学习来源

:灵茶山艾府

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

相关文章:

  • 阿里巴巴网站如何做固定背景关键词优化多少钱
  • 沈阳图书设计公司seo千享科技
  • 找人做网站产生纠纷算诈骗吗qq营销推广方法和手段
  • 武汉网站的优化关键词排名优化易下拉排名
  • 如何制作局域网站品牌运营推广方案
  • 北京专业网站制作大概费用网络营销案例分享
  • 个人网站建设与维护网页自助建站
  • 旅游网站建设论文网站建设公司大全
  • 软件系统商城定制开发百度seo找哪里
  • 使用session和cookie实现网站自动登录 .netseo排名策略
  • 宁波网站制作企业seo技术是什么意思
  • 从事软件开发合肥seo按天收费
  • linux做网站方便吗软文广告100字
  • 温州手机网站建设wmwl郑州高端网站制作
  • 怎样评价一个网站做的好与不好培训机构加盟店排行榜
  • 建筑工程公司注册条件优化网站排名需要多少钱
  • 做一家新闻媒体网站多少钱做销售记住这十句口诀
  • 做借贷网站平台网页制作代码模板
  • 太原网站开发团队seo搜索排名优化
  • 转做批发鞋子的网站百度在线翻译
  • 企业数据查询网站百度搜索一下百度
  • 最便宜做个网站多少钱网站在线生成app
  • 上传自己做的网站淘宝店铺转让价格表
  • 网站开发百灵鸟深圳产品网络推广
  • 文教设施网站制作方案百度推广方案
  • wordpress versionseo搜索引擎优化怎么做
  • 我想采集散文 做网站seo技术分享免费咨询
  • 大连微信网站制作域名注册购买
  • 网站做直播需要办理什么证泰安百度推广公司
  • 建设网站需要体现的流程有哪些数据分析培训机构哪家好