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

整数数组匹配

有两个数组a和b数组,都是正数的数组,a的数组总和在b数组中哪一块连续的空间差值最小,如果找到了,就打印b数组中的数组元素,首先解决这个问题需要有两个数组,还需要把a数组的总和求出来,求出来以后对比b数组,一个一个对比,两层循环,分别从0开始匹配,left不动,让right从1到最后以次累加起来和a数组总和进行对比,如果right所记录的值比求得的差值要小,就让min被重新赋值,然后记录当前的left和right,一直循环下去直到遍历完整个数组,打印templeft和tempright中间的值,这种方法是暴力求解,时间复杂最坏的情况下是O(n^2)

#include <stdio.h> int main() { //输入 int n=0; int m=0; scanf("%d %d",&n,&m);//两个值 int a[n]; int b[m]; int i=0; int sum=0; for(i=0;i<n;i++)//n是a { scanf("%d",&a[i]); sum+=a[i];//求得总和 } for(i=0;i<m;i++) { scanf("%d",&b[i]); } //得到了a数组的总大小 int min=INT_MAX;//把初始的min赋值为一个最大值 int left;//左边的下标 int right;//右边的下标 i=0;//i重新赋值为0,从下标为零开始循环 int tempsum=0;//记录每次right+1的值 int tempright=0;//记录需要被打印的右边下标 int templeft=0;//记录需要被打印的左边的下标 while(i<m)//m代表b { left=i;//开始都是从0开始累加 right=i; tempsum=0;//每次结束一次循环tempsum都要初始化为0 while(right<m)//right以次累加 { tempsum+=b[right];//累加 int tempmin=sum>tempsum?sum-tempsum:tempsum-sum;//计算差值,保证差值是正值 if(tempmin<min)//如果临时的差值比定义的差值小,就把right left tempmin赋值 { min=tempmin; tempright=right; templeft=left; } if(tempsum>=sum)//如果tmepsum都已经大于sum而且b数组都是正数,越加只会越大 { break; } right++;//向后累加 } i++;//遍历数组 } for(i=templeft;i<=tempright;i++) { printf("%d ",b[i]); } return 0; }
http://www.cnnetsun.cn/news/180460.html

相关文章:

  • 59、Windows 7 登录与安全设置全攻略
  • 计算机毕业设计springboot垂钓服务信息管理系统 基于SpringBoot的休闲垂钓综合服务平台 SpringBoot+MySQL垂钓社区与资源预约系统
  • Open-AutoGLM能帮你多赚20%?深度解析其复利计算引擎的三大黑科技
  • 从理论到落地:Open-AutoGLM量子协同的7个关键突破点
  • 为什么90%的Open-AutoGLM生物认证项目初期都失败了?真相在这里
  • Open-AutoGLM实战指南:9步实现量子-大模型联合训练,效率提升300%
  • 弹窗关闭失效怎么办?Open-AutoGLM高频故障应对策略大公开
  • springboot基于Java 足浴洗浴管理系统设计和实现_1fx39f1p
  • 还在手动算收益?Open-AutoGLM自动化计算让你效率提升10倍,秒出结果
  • 轴承(二维圆柱和二维球模型)和三维深沟球有限元模型画好网格,可直接拿去ansys仿真计算,适合...
  • 基于VUE的好利来蛋糕销售网站[VUE]-计算机毕业设计源码+LW文档
  • 拒绝无效加班!免费 RPA 工具合集,轻松搞定数据录入 / 报表整理
  • 【Open-AutoGLM量子协同突破】:揭秘量子计算与大模型融合的5大核心技术
  • 基于YOLOv11的苹果成熟度识别检测系统(YOLOv11深度学习+YOLO数据集+UI界面+登录注册界面+Python项目源码+模型)
  • 5个策略帮助企业充分利用YashanDB数据库
  • 5个策略提升你对YashanDB数据库的掌控力
  • 5个策略助力提升YashanDB数据库的可用性
  • 背调公司怎么选?一份基于核心维度的评估清单
  • 【独家披露】Open-AutoGLM内部训练数据曝光:它是如何学会“人性化”推荐的?
  • 还在手动查账单?Open-AutoGLM让你一键获取所有消费明细!
  • LangFlow内存管理策略:会话历史与状态持久化设置
  • SpringBoot+Vue 扶贫助农系统管理平台源码【适合毕设/课设/学习】Java+MySQL
  • 【验证码逆向专栏】某团验证码逆向分析
  • 华为云国际站代理商的CBR主要有什么作用呢?
  • LangFlow镜像单元测试生成:提高软件质量自动化保障
  • UG NX 2406:高端 CAD/CAE/CAM 一体化工程软件下载安装教程
  • AOP(面向切面编程,Aspect-Oriented Programming)
  • Open-AutoGLM调度性能提升300%?背后你不知道的5个优化秘诀
  • 揭秘Open-AutoGLM背后的技术栈:为何它能成为酒店业AI标杆?
  • 基于STM32的超声波倒车雷达测距报警OLED显示设计