leetcode--Search for a Range

本文介绍了一种在有序数组中快速查找指定目标值起始与终止位置的方法,并提供了一个Java实现示例,采用二分查找提高效率。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Given a sorted array of integers, find the starting and ending position of a given target value.

Your algorithm's runtime complexity must be in the order of O(log n).

If the target is not found in the array, return [-1, -1].

For example,
Given [5, 7, 7, 8, 8, 10] and target value 8,
return [3, 4].


题意:给定一个排序数组,有重复元素。给定一个target,在数组中找到target的其实位置和结束位置

要求时间复杂度为O(logn)

如果target不在数组中,返回[-1,1];

分类:数组,二分法


解法1:二分查找找到target所在位置。然后从该位置开始,向两边查找边缘。

[java]  view plain  copy
  1. public class Solution {  
  2.     public int[] searchRange(int[] nums, int target) {  
  3.         int[] res = new int[2];  
  4.         if(nums.length==0return new int[]{-1,-1};  
  5.         int low = 0;  
  6.         int high = nums.length-1;  
  7.         int mid = 0;          
  8.         while(low<=high){  
  9.             mid = (low+high)/2;  
  10.             if(nums[mid]==target) break;  
  11.             else if(nums[mid]>target) high = mid-1;  
  12.             else low = mid+1;  
  13.         }         
  14.         if(nums[mid]==target){            
  15.             int i = mid-1;            
  16.             while(i>=0 && nums[i]==target){                
  17.                 i--;  
  18.             }  
  19.             if(nums[i+1]==target)  
  20.                 res[0] = i+1;  
  21.             else  
  22.                 res[0] = mid;             
  23.             i = mid+1;  
  24.             while(i<nums.length&&nums[i]==target){                 
  25.                 i++;  
  26.             }  
  27.             if(nums[i-1]==target)  
  28.                 res[1] = i-1;  
  29.             else  
  30.                 res[1] = mid;                 
  31.             return res;  
  32.         }else{  
  33.             return new int[]{-1,-1};  
  34.         }  
  35.     }  

原文链接http://blog.youkuaiyun.com/crazy__chen/article/details/45675211

内容概要:本文档详细介绍了基于Google Earth Engine (GEE) 构建的阿比让绿地分析仪表盘的设计与实现。首先,定义了研究区域的几何图形并将其可视化。接着,通过云掩膜函数和裁剪操作预处理Sentinel-2遥感影像,筛选出高质量的数据用于后续分析。然后,计算中值图像并提取NDVI(归一化差异植被指数),进而识别绿地及其面积。此外,还实现了多个高级分析功能,如多年变化趋势分析、人口-绿地交叉分析、城市热岛效应分析、生物多样性评估、交通可达性分析、城市扩张分析以及自动生成优化建议等。最后,提供了数据导出、移动端适配和报告生成功能,确保系统的实用性和便捷性。 适合人群:具备一定地理信息系统(GIS)和遥感基础知识的专业人士,如城市规划师、环境科学家、生态学家等。 使用场景及目标:①评估城市绿地分布及其变化趋势;②分析绿地与人口的关系,为城市规划提供依据;③研究城市热岛效应及生物多样性,支持环境保护决策;④评估交通可达性,优化城市交通网络;⑤监测城市扩张情况,辅助土地利用管理。 其他说明:该系统不仅提供了丰富的可视化工具,还集成了多种空间分析方法,能够帮助用户深入理解城市绿地的空间特征及其对环境和社会的影响。同时,系统支持移动端适配,方便随时随地进行分析。用户可以根据实际需求选择不同的分析模块,生成定制化的报告,为城市管理提供科学依据。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值