豆包MarsCode:构造特定数组的逆序拼接

问题描述

在这里插入图片描述


思路分析

1. 数组的组成:

  • 我们要根据 i 的不同值拼接出不同长度的子数组。
  • 对于每个 i 从 1 到 n,我们要把数字从 n 逆序到 i 拼接成一个子数组。
    • 例如,当 i = 1 时,拼接 [n, n-1, ..., 1]
    • i = 2 时,拼接 [n, n-1, ..., 2]
    • 一直到 i = n,拼接的数组只有 [n]

2. 数组的拼接顺序:

  • 每次拼接的数组要依次放入最终结果数组中。因此,我们需要有一个结果数组来保存这些拼接后的数组。

3. 计算结果数组的长度:

  • 每个子数组的长度是由当前 i 决定的。对于 i = 1,拼接的是 n1,长度为 n;对于 i = 2,拼接的是 n2,长度为 n-1;依此类推,直到 i = n,拼接的数组长度为 1。

  • 因此,总长度就是:

    totalLength = n + ( n − 1 ) + ( n − 2 ) + . . . + 1 = n ( n + 1 ) 2 \text{totalLength} = n + (n-1) + (n-2) + ... + 1 = \frac{n(n+1)}{2} totalLength=n+(n1)+(n2)+...+1=2n(n+1)

    显而易见这是一个等差数列的求和公式。

4. 实现步骤:

  • 第一步,计算最终数组的总长度(totalLength)。
  • 第二步,创建一个大小为 totalLength 的结果数组。
  • 第三步,使用两层循环:
    • 外层循环遍历 i 从 1 到 n
    • 内层循环从 n 逆序填充到当前的 i
  • 最后,返回这个结果数组。

参考代码(Java)

import java.util.Arrays;public class Main {public static int[] solution(int n) {// 先计算出数组的总长度int totalLength = 0;for (int i = 1; i <= n; i++) {totalLength += (n - i + 1);}// 创建一个结果数组int[] result = new int[totalLength];int index = 0;// 按照规则填充结果数组for (int i = 1; i <= n; i++) {// 填充当前的部分 [n, n-1, ..., i]for (int j = n; j >= i; j--) {result[index++] = j;}}return result;}public static void main(String[] args) {System.out.println(Arrays.equals(solution(3), new int[]{3, 2, 1, 3, 2, 3}));System.out.println(Arrays.equals(solution(4), new int[]{4, 3, 2, 1, 4, 3, 2, 4, 3, 4}));System.out.println(Arrays.equals(solution(5), new int[]{5, 4, 3, 2, 1, 5, 4, 3, 2, 5, 4, 3, 5, 4, 5}));}
}

代码分析

1. 计算数组总长度

int totalLength = 0;
for (int i = 1; i <= n; i++) {totalLength += (n - i + 1);
}
  • 在这个部分,代码通过一个循环来计算最终结果数组的总长度。
  • 对于每个 i 从 1 到 n,我们需要拼接一个长度为 (n - i + 1) 的子数组。例如:
    • i = 1 时,长度是 n(拼接 [n, n-1, ..., 1])。
    • i = 2 时,长度是 n - 1(拼接 [n, n-1, ..., 2])。
    • 一直到 i = n 时,长度是 1(拼接 [n])。
  • 将每个长度累加,最终得出结果数组的总长度。

2. 创建结果数组

int[] result = new int[totalLength];
int index = 0;
  • 根据计算得到的 totalLength 创建一个新的整数数组 result,用来存储最终拼接的结果。
  • 使用 index 来跟踪我们在 result 数组中的位置。每次填充一个元素时,index 会增加。

3. 填充结果数组

for (int i = 1; i <= n; i++) {// 填充当前的部分 [n, n-1, ..., i]for (int j = n; j >= i; j--) {result[index++] = j;}
}
  • 外层循环:i 从 1 遍历到 n,代表我们要填充的每个子数组的起始位置。
  • 内层循环:对于每个 i,从 ni 逆序填充结果数组。内层循环的次数由 i 决定:
    • 对于 i = 1,内层循环会填充 n, n-1, ..., 1
    • 对于 i = 2,内层循环会填充 n, n-1, ..., 2
    • 直到 i = n,只填充 n
  • 每次填充一个数字时,index 会增加,确保结果数组按顺序填充。

4. 返回结果

return result;
  • 完成数组的填充后,返回这个 result 数组。

总结:

  • 核心逻辑:通过两层循环实现从 ni 的逆序拼接。
  • 时间复杂度 O ( n 2 ) O(n^2) O(n2),因为内外循环的嵌套导致操作次数随着 n n n 增加而呈二次增长。
  • 空间复杂度 O ( n 2 ) O(n^2) O(n2),因为我们创建了一个长度为 n ( n + 1 ) / 2 n(n+1)/2 n(n+1)/2 的数组来保存结果。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/diannao/67481.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

RK3588平台开发系列讲解(NPU篇)NPU 驱动的组成

文章目录 一、NPU 驱动组成二、查询 NPU 驱动版本三、查询 rknn_server 版本四、查询 librknn_runtime 版本沉淀、分享、成长,让自己和他人都能有所收获!😄 一、NPU 驱动组成 NPU 驱动版本、rknn_server 版本、librknn_runtime 版本以及 RKNN Toolkit 版本的对应关系尤为重…

论文阅读:CosAE Learnable Fourier Series for Image Restoration

这是 2024 NeurIPS 上发表的一篇文章&#xff0c;介绍了一种新型的基于傅里叶级数的通用编码器。 Abstract 本文介绍了余弦自动编码器&#xff08;Cosine Autoencoder, CosAE&#xff09;&#xff0c;这是一种新颖的通用自动编码器&#xff0c;它将经典傅里叶级数与前馈神经网…

YOLOv11改进,YOLOv11检测头融合RepConv卷积,并添加小目标检测层(四头检测),适合目标检测、分割等任务

摘要 作者提出了一种简单而强大的卷积神经网络架构,其推理阶段采用与 VGG 类似的网络体结构,仅由一堆 3x3 卷积和 ReLU 组成,而训练阶段的模型具有多分支拓扑。这种训练阶段和推理阶段架构的解耦通过结构重参数化技术实现,因此我们将该模型命名为 RepVGG。 # 理论介绍 Re…

深度学习笔记——循环神经网络RNN

大家好&#xff0c;这里是好评笔记&#xff0c;公主号&#xff1a;Goodnote&#xff0c;专栏文章私信限时Free。本文详细介绍面试过程中可能遇到的循环神经网络RNN知识点。 文章目录 文本特征提取的方法1. 基础方法1.1 词袋模型&#xff08;Bag of Words, BOW&#xff09;工作原…

Selenium工具使用Python 语言实现下拉框定位操作

&#x1f345; 点击文末小卡片&#xff0c;免费获取软件测试全套资料&#xff0c;资料在手&#xff0c;涨薪更快 我们通常遇到的下拉框有显性的下拉框和隐性的下拉框&#xff1b;有的下拉框还可以进行单选或多选操作&#xff0c;在selenium中如何实现下拉框的定位通常使用selec…

使用 Continue 插件时,发现调用外部地址

https://us.i.posthog.com/e/?ip1&_1737025525924&ver1.163.0&compressiongzip-js 看是一个帮助改善产品的网址。估计类似某推广流量监控的插件工具吧。网上没用查到其他说明&#xff0c;可能国内使用不多的原因。 但是发送的数据看不出来是个什么内容。 我用来搜…

【PyQt】图像处理系统

[toc]pyqt实现图像处理系统 图像处理系统 1.创建阴影去除ui文件 2.阴影去除代码 1.创建阴影去除ui文件 UI文件效果图&#xff1a; 1.1QT Desiger设置组件 1.两个Pushbutton按钮 2.两个label来显示图像 3.Text Browser来显示输出信息 1.2布局的设置 1.先不使用任何La…

【Idea】编译Spring源码 read timeout 问题

Idea现在是大家工作中用的比较多的开发工具&#xff0c;尤其是做java开发的&#xff0c;那么做java开发&#xff0c;了解spring框架源码是提高自己技能水平的一个方式&#xff0c;所以会从spring 官网下载源码&#xff0c;导入到 Idea 工具并编译&#xff0c;但是发现build的时…

Linux 音视频入门到实战专栏(视频篇)视频编解码 MPP

文章目录 一、MPP 介绍二、获取和编译RKMPP库三、视频解码四、视频编码 沉淀、分享、成长&#xff0c;让自己和他人都能有所收获&#xff01;&#x1f604; &#x1f4e2;本篇将介绍如何调用alsa api来进行音频数据的播放和录制。 一、MPP 介绍 瑞芯微提供的媒体处理软件平台…

爬虫后的数据处理与使用(使用篇--实现分类预测)

&#xff08;&#xff09;紧接上文&#xff0c;在完成基本的数据处理后&#xff0c;接下来就是正常的使用了。当然怎么用&#xff0c;确实需要好好思考一下~ 上文&#xff1a;爬虫后的数据处理与使用&#xff08;处理篇&#xff09; 前言&#xff1a; 一般来说&#xff0c;我…

RabbitMQ--延迟队列

&#xff08;一&#xff09;延迟队列 1.概念 延迟队列是一种特殊的队列&#xff0c;消息被发送后&#xff0c;消费者并不会立刻拿到消息&#xff0c;而是等待一段时间后&#xff0c;消费者才可以从这个队列中拿到消息进行消费 2.应用场景 延迟队列的应用场景很多&#xff0c;…

flutter开发-figma交互设计图可以转换为flutter源代码-如何将设计图转换为flutter源代码-优雅草央千澈

flutter开发-figma交互设计图可以转换为flutter源代码-如何将设计图转换为flutter源代码-优雅草央千澈 开发背景 可能大家听过过蓝湖可以转ui设计图为vue.js&#xff0c;react native代码&#xff0c;那么请问听说过将figma的设计图转换为flutter源代码吗?本文优雅草央千澈带…

当设置dialog中有el-table时,并设置el-table区域的滚动,看到el-table中多了一条横线

问题&#xff1a;当设置dialog中有el-table时&#xff0c;并设置el-table区域的滚动&#xff0c;看到el-table中多了一条横线&#xff1b; 原因&#xff1a;el-table有一个before的伪元素作为表格的下边框下&#xff0c;初始的时候已设置&#xff0c;在滚动的时候并没有重新设置…

代理模式实现

一、概念&#xff1a;代理模式属于结构型设计模式。客户端不能直接访问一个对象&#xff0c;可以通过代理的第三者来间接访问该对象&#xff0c;代理对象控制着对于原对象的访问&#xff0c;并允许在客户端访问对象的前后进行一些扩展和处理&#xff1b;这种设置模式称为代理模…

windows 搭建flutter环境,开发windows程序

环境安装配置&#xff1a; 下载flutter sdk https://docs.flutter.dev/get-started/install/windows 下载到本地后&#xff0c;随便找个地方解压&#xff0c;然后配置下系统环境变量 编译windows程序本地需要安装vs2019或更新的开发环境 主要就这2步安装后就可以了&#xff0…

Redis系列之底层数据结构字典Dict

Redis系列之底层数据结构字典Dict Dict数据结构 Dict是Redis数据结构中使用最为频繁的复合型数据结构&#xff0c;本质上是一个哈希表 查看redis6.0版本的源码&#xff0c;链接&#xff1a;https://github.com/redis/redis/blob/6.0/src/dict.h 哈希表的结构定义&#xff1…

【Azure 架构师学习笔记】- Azure Function (2) --实操1

本文属于【Azure 架构师学习笔记】系列。 本文属于【Azure Function 】系列。 接上文【Azure 架构师学习笔记】- Azure Function (1) --环境搭建和背景介绍 前言 上一文介绍了环境搭建&#xff0c;接下来就在本地环境下使用一下。 环境准备 这里我下载了最新的VS studio&…

【NextJS】PostgreSQL 遇上 Prisma ORM

NextJS 数据库 之 遇上Prisma ORM 前言一、环境要求二、概念介绍1、Prisma Schema Language&#xff08;PSL&#xff09; 结构描述语言1.1 概念1.2 组成1.2.1 Data Source 数据源1.2.2 Generators 生成器1.2.3 Data Model Definition 数据模型定义字段(数据)类型和约束关系&…

左神算法基础提升--3

文章目录 Manacher 算法经典算法Manacher算法原理 单调栈或单调队列 Manacher 算法 经典算法 在每学习Manacher算法之前我们可能会使用一种比较经典暴力的算法&#xff1a;遍历str字符串&#xff0c;将字符串中的每个字符作为对称点&#xff0c;向两边扩散找到回文字段&#x…

浅谈操作系统与初识Linux

一、Linux操作系统的出现 1.1操作系统的出现以及相关的四个要素 1.2最早出现的操作系统及其创始人 起初&#xff0c;IBM为了让计算机可以以更低技术成本进行使用&#xff0c;以此来售卖计算机&#xff1b; 为计算机搭载上了Unix操作系统&#xff0c;Unix由肯汤普森用汇编语…