iis服务器助手广告广告
返回顶部
首页 > 资讯 > 后端开发 > Python >Java算法之重新排列数组例题
  • 543
分享到

Java算法之重新排列数组例题

2024-04-02 19:04:59 543人浏览 薄情痞子

Python 官方文档:入门教程 => 点击学习

摘要

目录题目题目分析解题思路思路一思路二总结前言: 今天和大家分享一道简单,但是细节满满的算法题,其中一个思路反正我没有想到,但是很有用,分享出来希望对大家有帮助。 题目 给你一个数组

前言:

今天和大家分享一道简单,但是细节满满的算法题,其中一个思路反正我没有想到,但是很有用,分享出来希望对大家有帮助。

题目

给你一个数组 nums ,数组中有 2n 个元素,按 [x1,x2,...,xn,y1,y2,...,yn] 的格式排列。

请你将数组按 [x1,y1,x2,y2,...,xn,yn] 格式重新排列,返回重排后的数组。

示例 1:

输入:nums = [2,5,1,3,4,7], n = 3

输出:[2,3,5,4,1,7]

解释:由于 x1=2, x2=5, x3=1, y1=3, y2=4, y3=7 ,所以答案为 [2,3,5,4,1,7]

示例 2:

输入:nums = [1,2,3,4,4,3,2,1], n = 4

输出:[1,4,2,3,3,2,4,1]

示例 3:

输入:nums = [1,1,2,2], n = 2

输出:[1,2,1,2]

提示:

  • 1 <= n <= 500
  • nums.length == 2n
  • 1 <= nums[i] <= 10^3

题目分析

这是一道在力扣里面属于简单级别的题目,也很好理解。简单来说就是一个2n数组的长度进行重新排序,举个例子,比如n =10, 那么数组长度就是20,则:

nums[0] = nums[0]

nums[1] = nums[11]

nums[2] = nums[1]

nums[3] = nums[12]

nums[4] = nums[2]

nums[5] = nums[13]

nums[6] = nums[3]

......

解题思路

下面和大家分享两个解题思路,一个是比较常规的,另外一个是高阶的,反正我是想不到。

思路一

根据上面的例子,可以得出规律如下, 遍历n,

nums[2 * i] = nums[i],

nums[2*i + 1] = nums[n + i]

class Solution {
     public int[] shuffle(int[] nums, int n) {
        int[] bak = new int[2 * n];
        for (int i = 0; i < n; i++) {
            bak[2 * i] = nums[i];
            bak[2 * i + 1] = nums[i + n];
        }
        return bak;
    }
}

空间复杂度: O(n)

时间复杂度: O(n)

思路二

有没有更好的思路呢,能否让空间复杂度是O(1),不需要利用额外的数组。这里我们关注到题目的一个细节1 <= nums[i] <= 10^3, 也就是说nums数组的值最大是1000,换算二进制的话,也就是占用10位,而int的话在java中占用32位。我们能否用高位存储低位的内容? 显然是可以的。

  • 通过1023换算成二进制1111111111,不足32位,用0补齐,和数组的数值做&运算,可以得到数值的低10位的值。
  • 然后通过左移运算,移动10位,到高10位中。
  • 最后把高10位数据移动到第10位,就是最后的结果了。
class Solution {
     public int[] shuffle(int[] nums, int n) {
        for (int i = 0; i < n; i++) {
            // 先取出低10位,然后左移,需要加括号,因为<<优先级更高
            nums[2 * i] |= (nums[i] & 1023) << 10;
            nums[2 * i + 1] |= (nums[i + n] & 1023) << 10;
        }
        // 高10位右移
        for (int i = 0; i < 2 * n; i++) {
            nums[i] >>= 10;
        }
        return nums;
    }
}

空间复杂度: O(1)

时间复杂度: O(n)

总结

这道题的思路2用到了位运算符,正好我也最近学习了这个内容,所以分享出来,关于位运算符的使用可以参考java  常见位逻辑运算符梳理

到此这篇关于Java算法之重新排列数组例题的文章就介绍到这了,更多相关Java 排列数组内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

--结束END--

本文标题: Java算法之重新排列数组例题

本文链接: https://www.lsjlt.com/news/166308.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • Java算法之重新排列数组例题
    目录题目题目分析解题思路思路一思路二总结前言: 今天和大家分享一道简单,但是细节满满的算法题,其中一个思路反正我没有想到,但是很有用,分享出来希望对大家有帮助。 题目 给你一个数组 ...
    99+
    2024-04-02
  • java实现排列组合算法
    我这里只写了组合的算法。         假设现有 M=4 个数据 a,b,c,d。从中随机抽取n个数,n为1—4个数据进行组合。那么数学中的计算组合方式为C(4,1) + C(4,2) + C(4,3) + C(4,4)  = 4 + 6...
    99+
    2023-09-01
    排列组合 数据结构 java
  • JavaC++算法题解leetcode1592重新排列单词间的空格
    目录题目要求思路:模拟JavaC++Rust题目要求 思路:模拟 模拟就完了统计空格数量和单词数量,计算单词间应有的空格数,将它们依次放入结果字符串,若有余数则在末尾进行填补。 ...
    99+
    2024-04-02
  • Java数据结构与算法系列精讲之排序算法
    概述 从今天开始, 小白我将带大家开启 Java 数据结构 & 算法的新篇章. 冒泡排序 冒泡排序 (Bubble Sort) 是一种简单的排序算法. 它重复地遍历要排序的...
    99+
    2024-04-02
  • java如何实现排列组合算法
    这篇文章主要介绍java如何实现排列组合算法,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!java排列组合算法[@more@]import java.util.ArrayList;import j...
    99+
    2023-06-03
  • Java基于递归解决全排列问题算法示例
    本文实例讲述了Java基于递归解决全排列问题算法。分享给大家供大家参考,具体如下:排列问题设R={r1,r2,...,rn}是要进行排列的n个元素,Ri=R-{ri}。集合x中元素的全排列记为Perm(X)。(ri)Perm(X)表示在全排...
    99+
    2023-05-30
    java 递归 全排列
  • 如何用Java实现排列组合算法
    目录需求从排列到组合-穷举从排列到组合-分治分治思想代码实现直击本质-位运算思想代码实现小结需求 我们的数据表有多个维度,任意多个维度组合后进行 group by 可能会产生一些”奇...
    99+
    2024-04-02
  • 剑指Offer之Java算法习题精讲排列与N叉树
    题目一  解法 class Solution { LinkedList<List<Integer>> ans = new LinkedList&...
    99+
    2024-04-02
  • Java算法之堆排序代码示例
    堆是一种特殊的完全二叉树,其特点是所有父节点都比子节点要小,或者所有父节点都比字节点要大。前一种称为最小堆,后一种称为最大堆。比如下面这两个: 那么这个特性有什么作用?既然题目是堆排序,那么肯定能用来排序。想要用堆排序首先要创建一...
    99+
    2023-05-30
    java 算法实例 ava
  • Java 数据结构与算法系列精讲之数组
    目录概述数组声明数组的两个方法创建数组的两个方法索引自定义数组泛型构造函数元素操作调用完整代码概述 从今天开始, 小白我将带大家开启 Jave 数据结构 & 算法的新篇章. ...
    99+
    2024-04-02
  • java排序算法之_选择排序(实例讲解)
    选择排序是一种非常简单的排序算法,从字面意思我们就可以知道,选择就是从未排序好的序列中选择出最小(最大)的元素,然后与第 i 趟排序的第 i-1(数组中下标从 0 开始) 个位置的元素进行交换,第 i 个元素之前的序列就是已经排序好的序列。...
    99+
    2023-05-31
    java 选择排序 算法
  • java算法题解Leetcode15三数之和实例
    目录题目解题思路题目 15. 三数之和 给你一个包含 n 个整数的数组 nums,判断 nums 中是否存在三个元素 a,b,c ,使得 a + b + c = 0 ?请你找出所...
    99+
    2023-01-05
    java算法三数之和 java Leetcode
  • 剑指Offer之Java算法习题精讲数组与字符和等差数列
    题目一  解法 class Solution { public int[] relativeSortArray(int[] arr1, int[] arr2) { ...
    99+
    2024-04-02
  • JAVA十大排序算法之基数排序详解
    目录基数排序代码实现时间复杂度算法稳定性基数排序 vs 桶排序 vs 计数排序总结基数排序 常见的数据元素一般是由若干位组成的,比如字符串由若干字符组成,整数由若干位0~9数字组成。...
    99+
    2024-04-02
  • Java十大排序算法之计数排序刨析
    计数排序是非比较的排序算法,用辅助数组对数组中出现的数字计数,元素转下标,下标转元素 计数排序优缺点 优点:快 缺点:数据范围很大,比较稀疏,会导致辅助空间很大,造成空间的浪费 使用...
    99+
    2024-04-02
  • Java排序算法之计数排序如何实现
    这篇文章主要为大家展示了“Java排序算法之计数排序如何实现”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“Java排序算法之计数排序如何实现”这篇文章吧。计数排序是非比较的排序算法,用辅助数组对...
    99+
    2023-06-21
  • JAVA十大排序算法之计数排序详解
    目录计数排序问题代码实现时间复杂度算法稳定性总结计数排序 一种非比较排序。计数排序对一定范围内的整数排序时候的速度非常快,一般快于其他排序算法。但计数排序局限性比较大,只限于对整数进...
    99+
    2024-04-02
  • Java算法之最长公共子序列问题(LCS)实例分析
    本文实例讲述了Java算法之最长公共子序列问题(LCS)。分享给大家供大家参考,具体如下:问题描述:一个给定序列的子序列是在该序列中删去若干元素后得到的序列。确切地说,若给定序列X= { x1, x2,…, xm},则另一序列Z= {z1,...
    99+
    2023-05-30
    java 算法 最长公共子序列
  • java 基本算法之归并排序实例代码
    java 基本算法之归并排序实例代码原理:归并(Merge)排序法是将两个(或两个以上)有序表合并成一个新的有序表,     * 即把待排序序列分为若干个子序列,每个子序列是有序的。 &nb...
    99+
    2023-05-31
    java 归并排序 ava
  • java数据结构与算法数组模拟队列示例详解
    目录一、什么是队列二、用数组来模拟队列一、什么是队列 队列是一个有序列表,可以用数组或者链表来实现。遵循先入先出的原则,即:先存入队列的数据,要先取出。后存入的的数据,后取出。 看一...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作