【算法学习】1470. 重新排列数组(java / c / c++ / python / go / rust)

简介: 给你一个数组 nums ,数组中有 2n 个元素,按 [x1,x2,...,xn,y1,y2,...,yn] 的格式排列。请你将数组按 [x1,y1,x2,y2,...,xn,yn] 格式重新排列,返回重排后的数组。

1470. 重新排列数组:

给你一个数组 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

分析

  • 这道算法题是简单题,所以又可以重拳出击了。
  • 返回的结果不算在空间复杂度上,所以直接开辟新的空间赋值返回结果就可以了。
  • 但是二当家的发现可以难为自己,于是又灵机一动,原地排列,我真是个小机灵鬼。
  • 想要原地排列就一定要存储中间结果,原来的位置被占以后,需要知道原来位置的数字。
  • 提示里说每个数字最大不超过1000,而且都是正数,所以只需要用10个二进制位就够了。
  • 参数传递进来的数组一般都是int型数组,int型一般都是32位,够存题目中的2个数了。

题解

java

class Solution {
    public int[] shuffle(int[] nums, int n) {
        // 申请新的数组,这样用空间换时间
        int[] ans = new int[n * 2];
        for (int i = 0; i < n; ++i) {
            ans[2 * i] = nums[i];
            ans[2 * i + 1] = nums[n + i];
        }
        return ans;
    }
}
class Solution {
    public int[] shuffle(int[] nums, int n) {
        // 原地排列,时间换空间
        for (int i = 0; i < n; ++i) {
            // 把重排列的值左移10位
            nums[2 * i] |= (nums[i] & 0b1111111111) << 10;
            nums[2 * i + 1] |= (nums[n + i] & 0b1111111111) << 10;
        }
        // 将结果右移10位,低10位的原值没用了
        for (int i = 0; i < n; ++i) {
            nums[2 * i] >>= 10;
            nums[2 * i + 1] >>= 10;
        }
        return nums;
    }
}

c

/**
 * Note: The returned array must be malloced, assume caller calls free().
 */
int* shuffle(int* nums, int numsSize, int n, int* returnSize){
    // 申请新的数组,这样用空间换时间
    int *ans = (int *) malloc(sizeof(int) * numsSize);
    for (int i = 0; i < n; ++i) {
        ans[2 * i] = nums[i];
        ans[2 * i + 1] = nums[n + i];
    }
    *returnSize = numsSize;
    return ans;
}
/**
 * Note: The returned array must be malloced, assume caller calls free().
 */
int* shuffle(int* nums, int numsSize, int n, int* returnSize){
    // 原地排列,时间换空间
    for (int i = 0; i < n; ++i) {
        // 把重排列的值左移10位
        nums[2 * i] |= (nums[i] & 0b1111111111) << 10;
        nums[2 * i + 1] |= (nums[n + i] & 0b1111111111) << 10;
    }
    // 将结果右移10位,低10位的原值没用了
    for (int i = 0; i < n; ++i) {
        nums[2 * i] >>= 10;
        nums[2 * i + 1] >>= 10;
    }
    *returnSize = numsSize;
    return nums;
}

c++

class Solution {
public:
    vector<int> shuffle(vector<int>& nums, int n) {
        // 申请新的数组,这样用空间换时间
        vector<int> ans;
        for (int i = 0; i < n; ++i) {
            ans.push_back(nums[i]);
            ans.push_back(nums[n + i]);
        }
        return ans;
    }
};
class Solution {
public:
    vector<int> shuffle(vector<int>& nums, int n) {
        // 原地排列,时间换空间
        for (int i = 0; i < n; ++i) {
            // 把重排列的值左移10位
            nums[2 * i] |= (nums[i] & 0b1111111111) << 10;
            nums[2 * i + 1] |= (nums[n + i] & 0b1111111111) << 10;
        }
        // 将结果右移10位,低10位的原值没用了
        for (int i = 0; i < n; ++i) {
            nums[2 * i] >>= 10;
            nums[2 * i + 1] >>= 10;
        }
        return nums;
    }
};

python

class Solution:
    def shuffle(self, nums: List[int], n: int) -> List[int]:
        # 申请新的数组,这样用空间换时间
        ans = []
        for i in range(n):
            ans.append(nums[i]) 
            ans.append(nums[n + i])
        return ans
class Solution:
    def shuffle(self, nums: List[int], n: int) -> List[int]:
        # 原地排列,时间换空间
        for i in range(n):
            # 把重排列的值左移10位
            nums[2 * i] |= (nums[i] & 0b1111111111) << 10;
            nums[2 * i + 1] |= (nums[n + i] & 0b1111111111) << 10
        # 将结果右移10位,低10位的原值没用了
        for i in range(n):
            nums[2 * i] >>= 10
            nums[2 * i + 1] >>= 10
        return nums

go

func shuffle(nums []int, n int) []int {
    // 申请新的数组,这样用空间换时间
    ans := make([]int, 0, n*2)
    for i := 0; i < n; i++ {
      ans = append(ans, nums[i], nums[n+i])
    }
    return ans
}
func shuffle(nums []int, n int) []int {
    // 原地排列,时间换空间
    for i := 0; i < n; i++ {
      // 把重排列的值左移10位
      nums[2*i] |= (nums[i] & 0b1111111111) << 10
      nums[2*i+1] |= (nums[n+i] & 0b1111111111) << 10
    }
    // 将结果右移10位,低10位的原值没用了
    for i := 0; i < n; i++ {
      nums[2*i] >>= 10
      nums[2*i+1] >>= 10
    }
    return nums
}

rust

impl Solution {
    pub fn shuffle(nums: Vec<i32>, n: i32) -> Vec<i32> {
        let n: usize = n as usize;
        // 申请新的数组,这样用空间换时间
        let mut ans = Vec::new();
        (0..n).for_each(|i| {
            ans.push(nums[i]);
            ans.push(nums[n + i]);
        });
        ans
    }
}
impl Solution {
    pub fn shuffle(nums: Vec<i32>, n: i32) -> Vec<i32> {
        let mut nums = nums;
        let n = n as usize;
        // 原地排列,时间换空间
        (0..n).for_each(|i| {
            // 把重排列的值左移10位
            nums[2 * i] |= (nums[i] & 0b1111111111) << 10;
            nums[2 * i + 1] |= (nums[n + i] & 0b1111111111) << 10;
        });
        // 将结果右移10位,低10位的原值没用了
        (0..n).for_each(|i| {
            nums[2 * i] >>= 10;
            nums[2 * i + 1] >>= 10;
        });
        nums
    }
}

在这里插入图片描述


非常感谢你阅读本文~
放弃不难,但坚持一定很酷~
希望我们大家都能每天进步一点点~
本文由 二当家的白帽子:https://developer.aliyun.com/profile/sqd6avc7qgj7y 博客原创~

相关文章
|
6月前
|
存储 Rust 网络协议
【Rust学习】10_定义枚举
在这一章我们学习 枚举(enumerations),也被称作 enums。枚举允许你通过列举可能的 成员(variants) 来定义一个类型。首先,我们会定义并使用一个枚举来展示它是如何连同数据一起编码信息的。接下来,我们会探索一个特别有用的枚举,叫做 Option,它代表一个值要么是某个值要么什么都不是。然后会讲到在 match 表达式中用模式匹配,针对不同的枚举值编写相应要执行的代码。最后,我们将学习 if let 结构,另一个简洁方便处理代码中枚举的结构。
82 7
|
2月前
|
存储 监控 算法
关于员工上网监控系统中 PHP 关联数组算法的学术解析
在当代企业管理中,员工上网监控系统是维护信息安全和提升工作效率的关键工具。PHP 中的关联数组凭借其灵活的键值对存储方式,在记录员工网络活动、管理访问规则及分析上网行为等方面发挥重要作用。通过关联数组,系统能高效记录每位员工的上网历史,设定网站访问权限,并统计不同类型的网站访问频率,帮助企业洞察员工上网模式,发现潜在问题并采取相应管理措施,从而保障信息安全和提高工作效率。
45 7
|
3月前
|
存储 人工智能 算法
C 408—《数据结构》算法题基础篇—数组(通俗易懂)
408考研——《数据结构》算法题基础篇之数组。(408算法题的入门)
148 23
|
7月前
|
算法
Leetcode 初级算法 --- 数组篇
Leetcode 初级算法 --- 数组篇
78 0
|
5月前
|
Java Android开发 C++
Java和C++
Java和C++
85 15
|
7月前
|
算法 程序员 索引
数据结构与算法学习七:栈、数组模拟栈、单链表模拟栈、栈应用实例 实现 综合计算器
栈的基本概念、应用场景以及如何使用数组和单链表模拟栈,并展示了如何利用栈和中缀表达式实现一个综合计算器。
115 1
数据结构与算法学习七:栈、数组模拟栈、单链表模拟栈、栈应用实例 实现 综合计算器
|
7月前
|
Rust 算法 安全
学习Rust
【10月更文挑战第13天】学习Rust
140 8
|
7月前
|
Rust 安全 算法
Rust的学习
【10月更文挑战第12天】Rust的学习
78 2
|
7月前
|
Rust 算法 安全
如何学习Rust编程?
【10月更文挑战第12天】如何学习Rust编程?
149 1
|
7月前
|
存储 算法 定位技术
数据结构与算法学习二、稀疏数组与队列,数组模拟队列,模拟环形队列
这篇文章主要介绍了稀疏数组和队列的概念、应用实例以及如何使用数组模拟队列和环形队列的实现方法。
83 0
数据结构与算法学习二、稀疏数组与队列,数组模拟队列,模拟环形队列