LeetCode#34. Search for a Range

本文介绍了一种在有序数组中查找特定目标值起始和结束位置的方法,使用了二分查找并结合前后扫描的技术来高效解决问题。
  • 题目:一个有序整型数组和一个查找目标值,返回等于目标值的数组位置(起始位置)
    • 例子
      给定[5, 7, 7, 8, 8, 10]这个数组,目标值为8,返回结果为[3,4]
  • 难度:Medium
  • 思路:因为是一个有序的数组,又是查找目标值,所以自然想到用二分查找,但是这个题目需要在二分查找的基础上增加一个往前往后查找(即找到目标值后,需要看数组中是否还存在等于目标值的,找到等于目标值的位置范围) 实现这个只需要用两个while循环

  • 代码:

public class Solution {
    public int[] searchRange(int[] nums, int target) {
        int result[] = new int[2];
        result[0] = -1;
        result[1] = -1;
        if(nums == null || nums.length == 0 || target < nums[0] || target > nums[nums.length-1]){
            return result;
        }
        int low = 0;
        int high = nums.length-1;
        while(low <= high){
            int mid = low + (high-low)/2;
            if(target < nums[mid]){
                high = mid-1;
            }else if(target > nums[mid]){
                low = mid+1;
            }else{
                //找到目标值后,分别往前往后寻找下一个等于目标值的位置
                int start = mid;
                int end = mid;
                while(start > 0 && nums[start-1] == nums[start]){
                    start--;
                }
                while(end < nums.length-1 && nums[end+1] == nums[end]){
                    end++;
                }
                result[0] = start;
                result[1] = end;
                return result;
            }
        }
        return result;
    }
}
内容概要:本文档为《【顶刊复现】配电网两阶段鲁棒故障恢复研究(Matlab代码实现)》的技术资料汇总,聚焦电力系统中配电网在故障条件下的快速恢复问题,提出一种基于两阶段鲁棒优化的故障恢复模型。该模型在第一阶段制定预恢复策略,在第二阶段根据实际不确定性(如负荷波动、分布式电源出力波动)进行动态调整,从而增强系统应对突发故障的鲁棒性与恢复能力。研究完整实现了Matlab代码仿真,并融合Benders分解、混合整数线性规划(MILP)建模及YALMIP工具包调用等关键技术,具备较强的工程复现价值。文档还附带多个前沿科研方向资源,涵盖微电网优化、储能配置、电动汽车调度、风光制氢合成氨系统、无人机路径规划及机器学习预测等领域,形成综合性科研支持体系。所有资源通过指定网盘链接与微信公众号统一提供。; 适合人群:具备电力系统、自动化、电气工程或相关专业背景,熟悉Matlab/Simulink仿真环境,有一定优化算法基础的研究生、科研人员及工程技术人员。; 使用场景及目标:① 学习并复现顶刊级别的配电网故障恢复优化模型;② 掌握两阶段鲁棒优化在电力系统不确定性建模中的应用方法;③ 深入理解Benders分解、MILP建模、YALMIP工具包调用等核心技术;④ 拓展至微电网调度、综合能源系统优化、储能配置等相关课题的研究与仿真。; 阅读建议:建议读者结合文档中提供的网盘资源与代码实例,按主题分类系统学习,优先掌握两阶段鲁棒优化的核心建模思路,并借助Matlab平台动手实践,调试代码以加深对算法流程与参数设置的理解。同时可参考文中列出的同类研究方向,拓展科研视野。
下载代码方式:https://pan.quark.cn/s/9302347a1da6 一、项目概述 本系统是一个采用SSM框架构建的影院购票平台,亦称为影院售票平台或网络电影订购系统,主要面向计算机相关学科进行毕业设计的学子以及寻求项目实践操作的Java学习者。内容涵盖:项目源代码、项目相关文档、数据库构建脚本、所需软件工具等,该项目提供完整源代码可供毕业设计选用。所有项目均已执行严密调试,保证其可执行性!该系统具备完备的功能、视觉设计优雅、操作流程直观、功能覆盖全面、管理功能高效,展现出较高的实用应用潜力。 二、技术架构 后端架构:Spring框架、SpringMVC框架、MyBatis持久层框架 UI设计:BootStrap前端框架、jQuery交互库、JSP动态页面技术 ​ 数据存储:MySQL关系型数据库 三、系统构成 系统划分为前端订票模块与后台管理模块: 1. 前端订票模块 包含:用户注册流程、用户身份验证、电影目录浏览、按类别筛选电影、电影检索功能、电影详细信息展示、电影评论发布 在线购票流程、在线支付处理、个人账户中心、订单记录查阅 2. 后台管理模块 管理员功能:记录添加、记录列表展示、信息修改、记录删除、信息检索 用户数据管理:记录列表展示、记录删除、信息检索 公告信息管理:记录添加、记录列表展示、信息修改、记录删除、信息检索 电影分类管理:记录添加、记录列表展示、信息修改、记录删除、信息检索 地区信息管理:记录添加、记录列表展示、信息修改、记录删除、信息检索 影院设施管理:记录添加、记录列表展示、信息修改、记录删除、信息检索 电影内容管理:记录添加、记录列表展示、信息修改、记录删除、信息检索 订单记录管理:记录列表展示、信息修改、记录删除...
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值