1/14-C语言重排数组

c 复制代码
/**
 * Note: The returned array must be malloced, assume caller calls free().
 */
int* shuffle(int* nums, int numsSize, int n, int* returnSize) {
    // 补充:入参合法性校验(处理所有非法输入场景)
    if (nums == NULL || returnSize == NULL || n < 0 || numsSize != 2 * n) {
        // 避免对NULL指针解引用,仅当returnSize有效时重置为0
        if (returnSize != NULL) {
            *returnSize = 0;
        }
        return NULL;
    }
    //返回数组和原数组的长度一致。
    *returnSize=numsSize;
    int* result=(int*)malloc(*returnSize*sizeof(int));
    if(result==NULL){
        *returnSize=0;
        return NULL;
    }

    //4. 按规则填充新数组:[x1,y1,x2,y2,...,xn,yn]
    //按规则填充新数组:通过循环遍历0~n-1,每次循环同时处理xi和yi:
    //xi对应原数组索引i,填充到新数组索引2i(偶数位)。
    //yi对应原数组索引i+n(后n个元素的起始偏移为n),填充到新数组索引2i+1(奇数位)。
    for(int i=0;i<n;i++){
        // 填充xi:新数组偶数索引(0,2,4...)
        result[2*i]=nums[i];

        // 填充yi:也就是每个起始的后面的对应的yn 新数组奇数索引(1,3,5...)
        result[2*i+1]=nums[i+n];
    }       
    
    
    // 5. 返回动态分配的结果数组
    return result;
}
c 复制代码
int main() {
    int nums[] = {1,3,5,7,9,11};
    int returnSize;
    int* result = shuffle(nums, 6, 3, &returnSize);
    // 使用result数组...
    free(result); // 必须释放内存
}
 

代码功能分析

该函数实现数组重排功能,将输入数组按特定规则重新排列。输入数组包含2n个元素,前n个为x组,后n个为y组,输出数组格式为[x1,y1,x2,y2,...,xn,yn]

参数说明

  • nums:输入数组指针
  • numsSize:输入数组长度
  • n:分组大小(前n和后n)
  • returnSize:输出数组长度的指针

实现步骤

参数校验

检查输入指针有效性及参数合法性。若numsreturnSize为NULL,或n为负数,或numsSize不等于2n,则设置returnSize为0并返回NULL。

内存分配

为结果数组分配内存空间,大小为numsSize。若分配失败,设置returnSize为0并返回NULL。

数组重排 ------(核心步骤)

通过循环将原数组元素按规则填充到新数组:

  • 原数组前n个元素nums[i])放入新数组偶数索引2*i
  • 原数组后n个元素nums[i+n])放入新数组奇数索引2*i+1

结果返回

返回动态分配的结果数组指针,调用者需负责释放内存。

时间复杂度

该算法时间复杂度为O(n),仅需一次遍历即可完成数组重排。
空间复杂度为O(n),需要额外分配与输入数组等长的内存空间。

边界条件处理

  • 空指针输入
  • 负数分组大小
  • 数组长度不匹配
  • 内存分配失败
    所有异常情况均通过提前返回处理,避免程序崩溃。
复制代码
相关推荐
不穿格子的程序员2 小时前
从零开始刷算法——二叉树篇:验证二叉搜索树 + 二叉树中第k小的元素
java·开发语言·算法
老鼠只爱大米2 小时前
LeetCode算法题详解 76:最小覆盖子串
算法·leetcode·双指针·滑动窗口·最小覆盖子串·minwindow
HABuo2 小时前
【linux进程控制(一)】进程创建&退出-->fork&退出码详谈
linux·运维·服务器·c语言·c++·ubuntu·centos
郝学胜-神的一滴2 小时前
Python方法类型详解:类方法、静态方法与实例方法
开发语言·python·程序人生
CodeByV2 小时前
【算法题】链表
数据结构·算法
小杨同学492 小时前
【嵌入式 C 语言实战】单链表的完整实现与核心操作详解
后端·算法·架构
Tandy12356_2 小时前
手写TCP/IP协议栈——TCP数据接收
c语言·网络·网络协议·tcp/ip·计算机网络
码农胖虎-java2 小时前
【java并发编程】从源码角度彻底理解 ForkJoinPool.commonPool
java·开发语言·python
CQ_YM2 小时前
SQLite3 数据库与网页html
c语言·数据库·sqlite·html