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

360怎么做网站做预定网站的作用

360怎么做网站,做预定网站的作用,wordpress模板怎么安装教程,企业影视广告制作公司AcWing《蓝桥杯集训每日一题》—— 3956. 截断数组 文章目录AcWing《蓝桥杯集训每日一题》—— 3956. 截断数组一、题目二、解题思路三、代码实现本次博客我是通过Notion软件写的,转md文件可能不太美观,大家可以去我的博客中查看:北天的 BLOG…

AcWing《蓝桥杯集训·每日一题》—— 3956. 截断数组

文章目录

  • AcWing《蓝桥杯集训·每日一题》—— 3956. 截断数组
  • 一、题目
  • 二、解题思路
  • 三、代码实现

本次博客我是通过Notion软件写的,转md文件可能不太美观,大家可以去我的博客中查看:北天的 BLOG,持续更新中,另外这是我创建的编程学习小组频道,想一起学习的朋友可以一起!!!

一、题目

现在,要将该数组从中间截断,得到三个非空子数组。

要求,三个子数组内各元素之和都相等。

请问,共有多少种不同的截断方法?

输入格式

第一行包含整数n。

第二行包含n个整数a1, a2,… . , an。

输出格式

输出一个整数,表示截断方法数量。

数据范围

前六个测试点满足1≤n≤10。

所有测试点满足1≤<n≤10^5,-10000≤a_i≤10000。

输入样例1:

4
1 2 3 3

输出样例1:

1

输入样例2:

5
1 2 3 4 5

输出样例2:

0

输入样例3:

2
0 0

输出样例3:

0

二、解题思路

  1. 首先,需要确定数组的长度是否符合题目中的要求,也就是说,长度是否大于等于3。
  2. 如果数组的长度符合要求,您可以计算出数组的总和,并判断总和是否能够被3整除。
  3. 如果数组的总和可以被3整除,您可以计算出每个子数组的目标和。
  4. 接下来,您可以使用前缀和数组来预处理数组的前缀和。
  5. 然后,您可以遍历前缀和数组,如果当前前缀和等于目标和的两倍,则该点是可能的分割点。
  6. 最后,您可以从第一个可能的分割点开始,计算其他可能的分割点的数量,并将其加入答案。

通过使用前缀和,我们可以在O(n)的时间复杂度内解决此问题。

什么是前缀和?

前缀和是一种数学技巧,用于快速求出一个数组的前缀和。前缀和数组定义为:对于数组a中的每个元素a[i],前缀和数组prefix[i]表示a[0]到a[i]的和。

例如,对于数组a=[1, 2, 3, 4, 5],前缀和数组prefix为[1, 3, 6, 10, 15]。

使用前缀和数组可以在O(1)的时间复杂度内查询数组中某一段元素的和,而不需要重新遍历数组。这在很多题目中,如区间求和,有很多应用。

三、代码实现

def cut(n, nums):# 判断数组元素个数是否小于3,若是则不存在可行解,直接返回0if n < 3:return 0# 求数组元素和s = sum(nums)# 判断数组元素和是否为3的倍数,若不是则不存在可行解,直接返回0if s % 3 != 0:return 0# 将数组元素和除以3,得到每段的平均值avg = s // 3# 初始化cnt数组,用于存储每个前缀的符合要求的数量cnt = [0] * (n + 1)# 初始化presum数组,用于存储每个前缀的元素和presum = [0] * (n + 1)# 枚举每个前缀,计算元素和for i in range(1, n + 1):presum[i] = presum[i - 1] + nums[i - 1]# 枚举每个前缀,判断元素和是否为2倍的平均值for i in range(1, n):if presum[i] == avg * 2:cnt[i] = 1# 枚举每个前缀,累加符合要求的数量for i in range(1, n):cnt[i] += cnt[i - 1]# 初始化结果为0res = 0# 枚举每个前缀,判断元素和是否为平均值for i in range(n - 2):if presum[i + 1] == avg:res += cnt[n - 1] - cnt[i + 1]# 返回结果return resn = int(input().strip())
nums = list(map(int, input().strip().split()))
print(cut(n, nums))
http://www.yayakq.cn/news/475321/

相关文章:

  • 网站建设案例策划开发微网站
  • 如何跟客户沟通网站建设旅游后台网站
  • 广州网站建设技术weixinqqcom微信官网
  • 如何查询一个网站的空间服务商知识付费商城源码
  • 个人网站怎么做的模板推广seo公司
  • 大岭山镇做网站上海工程公司
  • 做公司网站需要花钱吗上海工商局企业信息查询
  • 常德网站开发公司网站建设服务收费
  • 做影视外包的网站中国室内设计装饰协会
  • wap网站制作模板杭州网站设计公司哪个好
  • 乐居房产官方网站北京二级建造师查询系统
  • 揭阳网站制作怎样发布活动的平台app
  • 免费网站建设pptwordpress go.php
  • 电商网站开发分享wordpress分类页首页调用分类描述
  • 网站ui怎么做的小程序代理与加盟
  • 做网站维护难吗俄罗斯网站制作
  • 为网站做seo需要什么软件石家庄微网站建设公司哪家好
  • 站长之家网站素材app开发语言有哪些
  • 中国邮政做特产得网站英文网站建设成都
  • 分类信息网站建设模板有网络网站打不开怎么回事
  • 月子中心网站建设需求广州番禺伤人案
  • 网站建设开发制作设计海南温州市网站建设公司
  • o2o网站建设代理商wordpress常用短代码
  • 网站设计参考wordpress数据库结构图
  • 沈阳市网站建设公司小程序免费制作平台系统
  • 网站开发前期方案我做微信淘宝客网站有哪些
  • 沈阳大十字街附近做网站公司很强大的网站运营方案1
  • 嘉兴备案网站乐清网站改版
  • 深圳一元网站建设公司做电影网站量刑标准
  • 电费由谁承担老铁seo外链工具