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),需要额外分配与输入数组等长的内存空间。

边界条件处理

  • 空指针输入
  • 负数分组大小
  • 数组长度不匹配
  • 内存分配失败
    所有异常情况均通过提前返回处理,避免程序崩溃。
复制代码
相关推荐
virus59453 小时前
悟空CRM mybatis-3.5.3-mapper.dtd错误解决方案
java·开发语言·mybatis
一匹电信狗3 小时前
【LeetCode_547_990】并查集的应用——省份数量 + 等式方程的可满足性
c++·算法·leetcode·职场和发展·stl
初次见面我叫泰隆3 小时前
Qt——3、常用控件
开发语言·qt·客户端
鱼跃鹰飞4 小时前
Leetcode会员尊享100题:270.最接近的二叉树值
数据结构·算法·leetcode
无小道4 小时前
Qt——QWidget
开发语言·qt
时艰.4 小时前
Java 并发编程之 CAS 与 Atomic 原子操作类
java·开发语言
梵刹古音5 小时前
【C语言】 函数基础与定义
c语言·开发语言·算法
筵陌5 小时前
算法:模拟
算法
梵刹古音5 小时前
【C语言】 结构化编程与选择结构
c语言·开发语言·嵌入式
Yvonne爱编码5 小时前
JAVA数据结构 DAY3-List接口
java·开发语言·windows·python