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

揭东建设局网站wordpress在服务器上安装插件

揭东建设局网站,wordpress在服务器上安装插件,长沙市网站制作哪家专业,广州免费领养猫咪剑指Offer(数据结构与算法面试题精讲)C版——day4 题目一:和为k的子数组题目二:0和1个数相同的子数组题目三:左右两边子数组的和相等 题目一:和为k的子数组 结合前面day3中的双指针法,我们显然可…

剑指Offer(数据结构与算法面试题精讲)C++版——day4

      • 题目一:和为k的子数组
      • 题目二:0和1个数相同的子数组
      • 题目三:左右两边子数组的和相等

题目一:和为k的子数组

在这里插入图片描述
    结合前面day3中的双指针法,我们显然可以想到使用双指针来处理,使用左指针p和右指针q,从左到右遍历数组,两个指针p和指针q中间的数组元素构成一个子数组,如果子数组和小于k那么将指针q向右移动,如果大于k那么将指针p向移动。这个方法存在一个问题,只适用于正整数,如果向右移子数组更小,那么起不到增加子数组和值的作用。
    因此,需要考虑使用其他方法,如果是直接使用蛮力法,那么需要借助于数组下标,差分出O(n^2)种左右不同边界,对于每一个子数组,为了计算和,还需要O(n)时间,因此蛮力法的时间复杂度为O(n^3),还是比较高的。分析发现,可以借助于数列和的特点来优化时间复杂度,也是一种空间换时间的方法,记Si表示数组从下标0-i之间的所有元素的和,那么在定界之后,比如说子数组的左右边界对应在数组中的下标为i和j,那么这段子数组的和值即为Sj-Si。这样得到的时间复杂度为O(n^2),最终得到的代码如下:

# include <iostream>
# include <algorithm>
using namespace std;
int findChildArrCount(int arr[],int len,int k) {int count=0,sum=0;int arrSum[len]= {0};for(int i=0; i<len; ++i) {sum+=arr[i];arrSum[i]=sum;}for(int i=0; i<len; ++i) {for(int j=i; j<len; ++j) {if((i==0&&arrSum[j]==k)||((arrSum[j]-arrSum[i-1])==k)) {count++;}}}return count;
}
int main() {int arr[]= {1,1,1};int len=sizeof(arr)/sizeof(arr[0]);int k=2;cout<<"这样的数组个数为:"<<findChildArrCount(arr,len,k);return 0;
}

在这里插入图片描述

题目二:0和1个数相同的子数组

在这里插入图片描述
    我们能够从前面题目一中关于子数列的和的相关内容获取灵感,从而想到一个简洁而有效的思路。就像之前处理问题那样,我们还是聚焦于计算数组中特定元素的和,这里着重考虑的是与统计偶数个数相关的和值计算。具体来说,我们设定
Si为数组从起始下标 0 到下标 i 这一区间内所有元素的总和,通过这种方式来构建一个便于后续分析的和值序列。
    当我们对数组进行定界操作时,会确定子数组的左右边界,不妨设子数组的左边界在数组中的下标为 i ,右边界下标为 j 。基于前面定义的 Si​,我们可以清晰地得出,这个子数组的和值能够通过 Sj​−Si 计算出来。
    接下来,我们需要对数组进行第二次遍历。在这次遍历过程中,我们会仔细检查定界指针 i 和 j 之间的子数组的元素和情况。这里存在两个关键的判断条件,缺一不可。一方面,定界指针 i 和 j 之间的子数组元素和必须恰好等于 (j−i+1)/2 ,这是由于我们要寻找的子数组中 0 和 1 的数量相等,所以其元素和必然是子数组长度的一半。另一方面,该子数组的长度必须是偶数,因为只有长度为偶数的情况下,才有可能实现 0 和 1 的个数相等这一目标。只有当这两个条件同时满足时,才能判定这样的子数组符合我们预先设定的要求。
    这种解决问题的方法在时间和空间复杂度上都具有明显的优势,其开销相对较小。从具体的操作流程来看,仅仅需要对数组进行两次遍历即可。第一次遍历主要是对数组元素进行求和统计,为后续的判断提供必要的数据支撑;第二次遍历则是在第一次遍历所得和值的基础上,逐一检查每个子数组的和是否恰好等于数组长度的一半,以此来筛选出符合条件的子数组。基于以上完整的思路,我们最终能够编写出相应的代码。

# include <iostream>
# include <algorithm>
using namespace std;
int findMaxLength(int arr[],int len) {int sum=0,maxLen=0;bool condition1,condition2;int arrSum[len]= {0};for(int i=0; i<len; ++i) {sum+=arr[i];arrSum[i]=sum;}for(int i=0; i<len; ++i) {for(int j=i; j<len; ++j) {condition1=(j-i+1)%2==0;//子数组的个数为偶数condition2=(i==0&&arrSum[j]==j/2)||(arrSum[j]-arrSum[i-1]==(j-i+1)/2);//满足和为个数的一半 if(condition1&&condition2&&(j-i+1)>maxLen) {//满足上述2个条件且超过当前最大子数组长度 maxLen=j-i+1;}}}return maxLen;
}
int main() {int arr[]= {0,1,0,1};int len=sizeof(arr)/sizeof(arr[0]);cout<<"这样的数组最大长度为:"<<findMaxLength(arr,len);return 0;
}

在这里插入图片描述

题目三:左右两边子数组的和相等

在这里插入图片描述
    结合前面两道题我们会发现,这种方法还特别好用,利用空间换时间。我们可以立即想到一个思路,第一次遍历数组,统计Si,那么对于给定的一个枢轴元素取为arr[k],我们只需要比较S(k-1)-S(i-1)S(len-1)-S(k)是否相等即可。
    这样需要消耗O(n)的空间复杂度,分析发现,其实我们只需要去统计整个数组的和(记为sum),以及前Si,那么后半段的和可以利用sum-arr[k]-S(k-1)拿到,这样空间复杂度就优化成了O(1)了。最终得到的代码如下:

# include <iostream>
# include <algorithm>
using namespace std;
int findPivotIndex(int arr[],int len) {int sum=0,tmpSum=0;for(int i=0; i<len; ++i) {//统一次总和sum+=arr[i];}for(int i=0; i<len-1; ++i) {tmpSum+=arr[i];//枢轴左半边的和if(i==0||i==len-1)continue;//排除枢轴在边界的情况if(tmpSum==sum-arr[i+1]) {return i;}}return -1;
}
int main() {int arr[]= {1,7,3,6,2,9};int len=sizeof(arr)/sizeof(arr[0]);cout<<"枢轴元素的下标为:"<<findPivotIndex(arr,len);return 0;
}

    这里补充两点说明:
(1)题目三中对于子数组,可能有些OJ平台会考虑到空数组的情况,需要根据实际判题结果来调整,这里是以子数组不能为空来编写的;
(2)需要注意一点,对于数组取和,最好使用long long来存储,可能有些测试数据的和值超过了INT的最大范围。
    我是【Jerry说前后端】,本系列精心挑选的算法题目全部基于经典的《剑指 Offer(数据结构与算法面试题精讲)》。在如今竞争激烈的技术求职环境下,算法能力已成为前端开发岗位笔试考核的关键要点。通过深入钻研这一系列算法题,大家能够系统地积累算法知识和解题经验。每一道题目的分析与解答过程,都像是一把钥匙,为大家打开一扇通往高效编程思维的大门,帮助大家逐步提升自己在数据结构运用、算法设计与优化等方面的能力。
    无论是即将踏入职场的应届毕业生,还是想要进一步提升自己技术水平的在职开发者,掌握扎实的算法知识都是提升竞争力的有力武器。希望大家能跟随我的步伐,在这个系列中不断学习、不断进步,为即将到来的前端笔试做好充分准备,顺利拿下心仪的工作机会!快来订阅吧,让我们一起开启这段算法学习之旅!


文章转载自:

http://QzEmZTVE.pycpt.cn
http://3rpooqg1.pycpt.cn
http://idvcS5VK.pycpt.cn
http://GH1Db2Oj.pycpt.cn
http://k8gOjb98.pycpt.cn
http://OkmBTzMq.pycpt.cn
http://34SS8xRo.pycpt.cn
http://mI3RB43u.pycpt.cn
http://Ll6pVSfa.pycpt.cn
http://MecJUBq8.pycpt.cn
http://Mkv7cUTT.pycpt.cn
http://rIKybhxK.pycpt.cn
http://lrOheKY2.pycpt.cn
http://5Abpuhup.pycpt.cn
http://zkcTOECh.pycpt.cn
http://9G3v56oD.pycpt.cn
http://lOCcKoS0.pycpt.cn
http://dtejlwV3.pycpt.cn
http://G7rw2oIV.pycpt.cn
http://42ZZamEy.pycpt.cn
http://fGV7u19y.pycpt.cn
http://Q1vct8Zd.pycpt.cn
http://h8f40LuC.pycpt.cn
http://Rwfa0DGh.pycpt.cn
http://FjB9y72E.pycpt.cn
http://CUbW0nVd.pycpt.cn
http://5kLSe0uT.pycpt.cn
http://PszoyTXc.pycpt.cn
http://p7Mj5T1L.pycpt.cn
http://kntYEZxl.pycpt.cn
http://www.dtcms.com/wzjs/713265.html

相关文章:

  • 深圳网站建设公司968网站域名改了帝国cms
  • 美团网站除佣金表格怎么做网站建设有钱赚吗
  • app导航网站建设多少钱做电商网站一般需要什么流程图
  • wordpress网站如何播放视频播放iis 里没有网站
  • 做网站如何与腾讯合作青州网站建设qzfuwu
  • 西安做网站哪里便宜网站建设合作报道
  • 制作企业宣传册用什么软件新网站seo优化
  • 完整网站建设案例教程网络推广培训哪个好
  • 网站是否需要备案长沙十大必去景点
  • 滨州建设厅网站wordpress 怎么加载js
  • 一个具体网站的seo优化企业邮箱腾讯
  • wordpress怎么做网盘站绵阳网站建设推广
  • 网站建设费入如保入账网站后台管理系统登陆
  • 郑州租赁房网站建设扬州建设工程交易网
  • 你的网站正在建设中河北廊坊公布新增阳性人员轨迹
  • 网站刚做怎么做seo优化wordpress按最后评论排序
  • 二手书网站开发网站开发总结文档
  • 网站建设如何弄链接网站建设域名是什么
  • 网站搭建崩溃单位网站的方案
  • 网站开发p6wordpress侧栏图片插件
  • wordpress网站管理员插件榆林北京网站建设
  • seo网站推广佛山网站推广的一般方式
  • 校园网站建设特色视觉传达设计是学什么的
  • 工程建设项目网站漯河专业做网站的公司
  • 汕头建站程序软文标题写作技巧
  • 龙岩找工作网站网站优化潍坊
  • 网页游戏推广网站怎么做html5响应式网站模板
  • 广州培训网站开发西安seo排名收费
  • 企业需要做网站吗建设网站注意事项
  • 丫个网站建设网页设计和制作的三大步骤