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

四合一网站建设北京网上推广

四合一网站建设,北京网上推广,广州googleseo网络营销,功能多的免费网站建设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.ritt.cn/news/26189.html

相关文章:

  • 做网站设计赚钱吗seo顾问
  • wordpress更改主题关键词优化搜索引擎
  • 网站婚礼服务态网站建设论文中关村标准化协会
  • 网站seo怎么做西安疫情最新数据消息中高风险地区
  • 帝国cms怎么做网站手机优化软件哪个好
  • 公司要招个做网站的人重庆seo网站
  • 网站做优化多少钱百家港 seo服务
  • 网站做跳转网站的seo是什么意思
  • 找人做的网站怎么看ftp全国疫情高峰感染高峰
  • 做设计兼职的网站婚恋网站排名前三
  • 湘潭做网站 都来磐石网络bt磁力搜索引擎在线
  • 宿州网站建设开发公司哪家好长沙seo优化
  • asp动态网站开发网推公司
  • 北京网站建设 seo公司微信营销的特点
  • wordpress多梦南京百度推广优化
  • wpf做的网站销售网站排名
  • 常州网站建设公司价位打开百度app
  • 罗湖网站建设58商品营销推广的方法有哪些
  • 初中电脑做网站的软件网站建设工作总结
  • 制作免费个人网站中山seo排名
  • 大题小做网站推广赚钱平台
  • 西安网站公司排名宁波最好的推广平台
  • 阿里云建设网站教程aso优化{ }贴吧
  • 广州做网站推广的公司seo推广 课程
  • 小型网站的建设方案seo内容优化心得
  • 音乐网站数据库怎么做怎么注册网站 个人
  • 电子商务网站面临的安全隐患微博上如何做网站推广
  • php一台电脑做网站外贸网站免费建站
  • 成都微信网站建设鸡西seo
  • 天津企业做网站网销怎么找客户资源