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

怎么增加网站的流量长沙网站优化价格

怎么增加网站的流量,长沙网站优化价格,可以在哪些网站 app做推广的,网站建设无锡海之睿一. 简介 本文记录力扣网上题目,涉及数组的逻辑题:在数组中搜索某个值,返回其index,如果没有则返回可以插入的index。 二. 力扣网C语言编程题:搜索插入位置 题目:搜索插入问题 给定一个排序数组和一个目…

一. 简介

本文记录力扣网上题目,涉及数组的逻辑题:在数组中搜索某个值,返回其index,如果没有则返回可以插入的index。

二. 力扣网C语言编程题:搜索插入位置

题目:搜索插入问题

给定一个排序数组和一个目标值,在数组中找到目标值,并返回其索引。如果目标值不存在于数组中,返回它将会被按顺序插入的位置。
要求:请必须使用时间复杂度为 O(log n) 的算法。

示例 1:
输入: nums = [1,3,5,6], target = 5
输出: 2

示例 2:
输入: nums = [1,3,5,6], target = 2
输出: 1

示例 3:
输入: nums = [1,3,5,6], target = 7
输出: 4

提示:
    1 <= nums.length <= 104
    -104 <= nums[i] <= 104
    nums 为 无重复元素 的 升序 排列数组
    -104 <= target <= 104

题目分析:

这道题目要求时间复杂度为logn,可以使用二分法实现。

题目说排序数组,一般默认情况下是升序数组,即数组中元素大小是从小到大排序的。

什么是二分法?

二分法又名二分查找法或折半查找法。二分法查找法是一种在有序数组或有序列表中查找特定元素的高效方法。

二分查找法因为每次迭代查找都会将区间折半,具体如下:

  • 初始搜索区间长度为 n
  • 第一次迭代后,区间长度变为 n/2
  • 第二次迭代后,区间长度变为 n/4
  • 以此类推,直到区间长度为 1(最多迭代 log₂n 次)。

因此,迭代次数的上界为 log₂n,每次迭代的操作(如计算中点、比较值)均为 O(1),故总时间复杂度为 O(log n)

解题思路:

1. 首先,定义左边界: left = 0,右边界: right  = n-1(其中n为数组的索引); 

2. 遍历数组,循环判断条件是 left <= right,这里 包含 left ==right的判断是考虑 target不在数组范围内的情况(可以通过例子来简单验证);

3. 循环内部:

(1)计算数组中间元素d的索引: mid = (left+right)/2;

(2)判断 target 与 nums[mid]这个中间值的大小:

如果 target == nums[mid];则返回 mid;

如果 target < nums[mid],则 说明 target在数组的左边,更改右边界:right = mid-1;

如果 target > nums[mid],则 说明 target在数组的右边,更改右边界:right = mid+1;

C语言实现如下:

//二分法
int searchInsert(int* nums, int numsSize, int target) {if((nums == NULL) || (numsSize <= 0)) {return -1;}  int left = 0;int right = numsSize-1;int mid = 0;//这里 left<=right判断,考虑target不是数组范围内的情况while(left <= right){mid = (left+right)/2;if(target == nums[mid]) {return mid;}//target < nums[mid]中间值,则说明target在数组左边//更改右边界:right= mid-1;else if(target < nums[mid]) {right = mid-1;}else {//target < nums[mid]中间值,则说明target在数组右边//更改右边界:left= mid+1;left = mid+1;}}return left;
}

可以看出,时间复杂度为 logn,空间复杂度为 O(1);

二分法使用 python实现如下:

class Solution:def searchInsert(self, nums: List[int], target: int) -> int:n = len(nums)left = 0      #左边界为数组首元素的索引right = (n-1) #右边界为数组最后一个元素的索引#这里left<=right判断,考虑target不是数组范围内的情况while(left <= right):mid = (left+right)//2 #python除法,向下取整if(target == nums[mid]):return midelif(target < nums[mid]):#target < 区间中间元素值,则说明target在数组左边right = mid-1else: #target > 区间中间的元素值,则说明target在数组的右边left = mid+1return left

http://www.dtcms.com/wzjs/297983.html

相关文章:

  • 泰安网站建设538sw做一套二级域名网站怎么做
  • 面对撞库 网站应该怎么做免费建站网站网页
  • 房地产网站建设与优化分析百度西安分公司地址
  • 杭州网站建设服务公司在百度怎么免费发布广告
  • 自动发货网站怎么做官网优化 报价
  • 建个网站做产品怎样seo优化快排
  • 济南做网站哪家公司好市场推广计划书
  • 腾讯云做网站怎么样链接优化方法
  • 商城网站建设软件网络营销的网站建设
  • 网站图片设计效果图站长工具果冻传媒
  • 电子商务网站的全面建设常用搜索引擎有哪些
  • vue做网站导航交换链接的方法
  • 网站程序制作教程太原关键词排名推广
  • 毕业设计网站建设流程国际时事新闻
  • 经典设计作品外贸网站seo优化
  • 常见的网络营销的方式有哪些站长工具seo推广秒收录
  • 群晖ds216j能否做网站网站交换链接的常见形式
  • 广州网站建设88武威网站seo
  • 国内网站建设发展营销和销售的区别
  • 免费做网站公司网站制作的步骤
  • 技术外包网站seo优化什么意思
  • 西部数码网站备份互联网广告代理
  • pc网站建设的三大条件济南网络推广网络营销
  • 如何设计公司网页网址seo查询
  • 成都最新房价一览表来客seo
  • 外贸网站建站用什么意思沈阳seo推广
  • 营销型网站是什么实时热搜榜榜单
  • 怎么查看一个网站页面的seo优化情况百度官方人工客服电话
  • 广东外贸网站建设山西网站seo
  • 如何做网站的301重定向上海最新新闻