ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

leetcode1588-所有奇数长度子数组的和

2022-09-04 14:02:45  阅读:147  来源: 互联网

标签:arr right 奇数 int 相加 数组 leetcode1588 odd left


 

https://leetcode.cn/problems/sum-of-all-odd-length-subarrays/

虽然知道几个嵌套循环暴力可以做,但是可以明显看出每一次都要经过很多重复计算,数组中每一个数字相加的次数是不同的,于是尝试看看相加的次数有什么规律。

其中大小为5的数组相加次数分别为3 4 5 4 3,大小为7的数组相加次数分别为4 6 8 8 8 6 4,实在看不出什么规律。

后来想到可以让程序计算出各种长度的数组各个位置的数相加的次数:每一次的相加都像一个滑动窗口?

class Solution { public:     int sumOddLengthSubarrays(vector<int>& arr) {         int sizes=arr.size(),sum=0;         int count[sizes];//记录各个数相加的次数         for(int i=0;i<sizes;i++)    count[i]=1;  //不管数组的大小是奇数还是偶数,都肯定会有一次相加         for(int i=3;i<=sizes;i+=2)//控制窗口大小   //所以窗口直接从3开始         {             for(int j=0;j<=sizes-i;j++)//控制窗口的移动             {                 for(int k=j;k<j+i;k++)  count[k]++;             }         }         for(int i=0;i<sizes;i++)         {             sum = sum + count[i]*arr[i];         }         return sum;     } }; 一开始提交是count初始化为0,窗口大小从1开始,用时4ms,更改之后直接变成0ms

 

还有一种比较神奇的做法,计算各个位置数字相加次数不需要那么多层循环。

class Solution {
public:
int sumOddLengthSubarrays(vector<int>& arr) {

  int res = 0;
  for(int i = 0; i < arr.size(); i ++)

  {
    int left = i + 1, right = arr.size() - i,
    left_even = (left + 1) / 2, right_even = (right + 1) / 2,
    left_odd = left / 2, right_odd = right / 2;
    res += (left_even * right_even + left_odd * right_odd) * arr[i];
  }
  return res;
}
};

作者:liuyubobobo
链接:https://leetcode.cn/problems/sum-of-all-odd-length-subarrays/solution/cong-on3-dao-on-de-jie-fa-by-liuyubobobo/

这个做法是先算每个位置包括它自己左右有多少个数字

因为奇数+奇数=偶数,偶数+偶数=偶数

如果左右两边分别选择的数字个数相加为偶数,则说明构成了长度为奇数的数组

 

 

 

 

标签:arr,right,奇数,int,相加,数组,leetcode1588,odd,left
来源: https://www.cnblogs.com/uacs2024/p/16654970.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有