数字在排序数组中出现的次数,有30个数组,每个数组里面有700个数,升序排列

  数字在排序数组中出现的次数,有30个数组,每个数组里面有700个数,升序排列

  NC74在升序排列中出现的次数

  知识点数组二分法

  说明给定一个长度为N的非降序数组和一个非负整数K,需要统计K在数组中出现的次数。

  数据范围:数组中每个元素的值满足

  需求:空间复杂度,时间复杂度

  示例1输入:

  [1,2,3,3,3,4,5],3返回值:

  4例2输入:

  [1,3,4,5],6返回值:

  0暴力解决问题省略~

  二元分解法

  #包含位/标准数据。h

  使用命名空间std

  int GetNumberOfK(向量int数据,int k)

  {

  if(data . size()==0 k data . front() k data . back())

  {

  返回0;

  }

  int left=0;

  int right=data . size()-1;

  int len=0;

  int mid

  while(左=右)

  {

  mid=(左右)/2;

  if (data[mid]==k)

  {

  打破;

  }

  if (k数据[mid])

  {

  右=中1;

  }

  其他

  {

  左=中1;

  }

  }

  int i=mid

  while (i=左数据[i]==k)

  {

  len

  I-;

  }

  I=mid 1;

  while (i=右数据[i]==k)

  {

  len

  我;

  }

  返回len

  }

郑重声明:本文由网友发布,不代表盛行IT的观点,版权归原作者所有,仅为传播更多信息之目的,如有侵权请联系,我们将第一时间修改或删除,多谢。

相关文章阅读

  • office2010激活密钥大全 怎么永久激活office2010
  • project2010产品密钥免费_project2010激活密钥永久激活码
  • c语言调用退出函数 c语言退出整个程序怎么写
  • c语言中怎么给函数初始化 c语言的初始化语句
  • c语言编写函数计算平均值 c语言求平均函数
  • chatgpt是什么?为什么这么火?
  • ChatGPT为什么注册不了?OpenAI ChatGPT的账号哪里可以注册?
  • OpenAI ChatGPT怎么注册账号?ChatGPT账号注册教程
  • chatgpt什么意思,什么是ChatGPT ?
  • CAD中怎么复制图形标注尺寸不变,CAD中怎么复制图形线性不变
  • cad中怎么创建并使用脚本文件,cad怎么运行脚本
  • cad中快速计算器的功能,cad怎么快速计算
  • cad中快速修改单位的方法有哪些,cad中快速修改单位的方法是
  • cad中心点画椭圆怎么做,cad轴测图怎么画椭圆
  • CAD中常用的快捷键,cad各种快捷键的用法
  • 留言与评论(共有 条评论)
       
    验证码: