博客
关于我
LeetCode笔记~5364. 按既定顺序创建目标数组
阅读量:290 次
发布时间:2019-03-03

本文共 1262 字,大约阅读时间需要 4 分钟。

要解决这个问题,我们需要创建一个目标数组 target,根据给定的 numsindex 数组中的元素进行插入操作。具体来说,我们需要按照顺序依次读取 nums[i]index[i],并在 target 数组中的 index[i] 处插入 nums[i]。在插入时,如果目标位置已经被占用,需要将后续元素依次后移以腾出位置。

方法思路

  • 初始化目标数组:创建一个与 nums 长度相同的数组 target,初始值为 -1。
  • 遍历处理:依次处理 numsindex 数组中的每个元素。
  • 插入检查:对于每个元素,检查目标位置是否为 -1。如果是,直接插入;如果不是,遍历从末尾开始,找到第一个可用的位置,并将后续元素依次后移。
  • 插入操作:将当前元素插入到找到位置,并调整后续元素的位置。
  • 这种方法确保了每个元素都能正确插入到指定的位置,同时保持插入顺序。

    解决代码

    import java.util.Arrays;public class Solution {    public int[] createTargetArray(int[] nums, int[] index) {        int[] target = new int[nums.length];        Arrays.fill(target, -1);        int i = 0;        while (i < nums.length) {            int currentIndex = index[i];            if (target[currentIndex] != -1) {                for (int j = nums.length - 1; j > currentIndex; j--) {                    if (target[j - 1] != -1) {                        target[j] = target[j - 1];                    }                }            }            target[currentIndex] = nums[i];            i++;        }        return target;    }}

    代码解释

  • 初始化数组:使用 Arrays.fill 初始化 target 数组为 -1。
  • 遍历循环:使用 while 循环遍历 numsindex 数组的元素。
  • 检查插入位置:对于每个元素,检查 target 数组中的 index[i] 是否为 -1。如果不是,进入一个从末尾开始遍历的循环,找到第一个可用的位置并进行后移调整。
  • 插入元素:将当前元素插入到找到位置,并继续处理下一个元素。
  • 这种方法确保了插入顺序的正确性,并且在处理过程中尽量减少了不必要的遍历,提高了效率。

    转载地址:http://arnl.baihongyu.com/

    你可能感兴趣的文章
    NUMPY矢量化np.prod不能构造具有超过32个操作数的ufunc
    查看>>
    Numpy矩阵与通用函数
    查看>>
    numpy绘制热力图
    查看>>
    numpy转PIL 报错TypeError: Cannot handle this data type
    查看>>
    Numpy闯关100题,我闯了95关,你呢?
    查看>>
    nump模块
    查看>>
    Nutch + solr 这个配合不错哦
    查看>>
    NuttX 构建系统
    查看>>
    NutUI:京东风格的轻量级 Vue 组件库
    查看>>
    NutzCodeInsight 2.0.7 发布,为 nutz-sqltpl 提供友好的 ide 支持
    查看>>
    NutzWk 5.1.5 发布,Java 微服务分布式开发框架
    查看>>
    NUUO网络视频录像机 css_parser.php 任意文件读取漏洞复现
    查看>>
    NUUO网络视频录像机 upload.php 任意文件上传漏洞复现
    查看>>
    Nuxt Time 使用指南
    查看>>
    NuxtJS 接口转发详解:Nitro 的用法与注意事项
    查看>>
    NVDIMM原理与应用之四:基于pstore 和 ramoops保存Kernel panic日志
    查看>>
    NVelocity标签使用详解
    查看>>
    NVelocity标签设置缓存的解决方案
    查看>>
    Nvidia Cudatoolkit 与 Conda Cudatoolkit
    查看>>
    NVIDIA GPU 的状态信息输出,由 `nvidia-smi` 命令生成
    查看>>