LeetCode 面试题 08.03. 魔术索引

文章目录

一、题目

  魔术索引。 在数组A[0...n-1] 中,有所谓的魔术索引,满足条件 A[i] = i。给定一个有序整数数组,编写一种方法找出魔术索引,若有的话,在数组A中找出一个魔术索引,如果没有,则返回-1。若有多个魔术索引,返回索引值最小的一个。

示例1:

输入: nums = 0, 2, 3, 4, 5
输出: 0
说明: 0下标的元素为0

示例2:

输入: nums = 1, 1, 1
输出: 1

说明:

  • nums长度在1, 1000000之间
  • 此题为原书中的 Follow-up,即数组中可能包含重复元素的版本

  点击此处跳转题目

二、C# 题解

  依次遍历,但是进行剪枝:如果当前值大于索引,则跳转到当前值的索引位置。

csharp 复制代码
public class Solution {
    public int FindMagicIndex(int[] nums) {
        if (nums[0] > nums.Length || nums[^1] < 0) return -1;
        int i = 0;
        while (i < nums.Length) {
            if (nums[i] == i) return i;   // 找到魔术索引,立即返回
            if (nums[i] > i) i = nums[i]; // 如果当前值大于索引,则跳转到当前值的索引位置
            else i++;                     // 否则,继续判断下一个位置
        }
        return -1;
    }
}
  • 时间:88 ms,击败 81.82% 使用 C# 的用户
  • 内存:41.7 MB,击败 72.73% 使用 C# 的用户
相关推荐
黎阳之光科技管控12 分钟前
纯视觉定位赋能海关口岸 无感通关提升国门安全与效率
算法·安全
じ☆冷颜〃21 分钟前
Picard–Lindelöf定理在CS中的应用:理论框架与算法基础
人工智能·经验分享·笔记·算法·机器学习
不知名的老吴26 分钟前
机器学习评价之基础指标
人工智能·算法·机器学习
Felven26 分钟前
D. Divisible Pairs
算法
源代码杀手27 分钟前
基于ROS2+Gazebo+RIVE的40项计算机视觉前沿机器人项目(含视觉算法原理与源码获取方式)
算法·计算机视觉·机器人
MrZhao40028 分钟前
大模型量化到底在做什么:从浮点数表示到 Qwen FP8 实践
算法
JieE21229 分钟前
LeetCode35. 搜索插入位置:二分查找的基础与细节
javascript·算法
8Qi835 分钟前
LeetCode 188 & 123:股票买卖问题(限制交易次数)—— 联合题解
算法·leetcode·职场和发展·动态规划
KaMeidebaby38 分钟前
卡梅德生物技术快报|细胞周期检测抗原流式分析:参数调试、软件拟合与问题排查
网络·人工智能·python·网络协议·tcp/ip·算法·机器学习
一只齐刘海的猫43 分钟前
【Leetcode】三数之和
数据结构·算法·leetcode