1929. 数组串联

文章介绍了如何编写一个C语言函数getConcatenation,接收一个整数数组nums,将其串联成两倍长度的新数组ans,满足ans[i]=nums[i]且ans[i+n]=nums[i]。给出了两个示例以展示函数的使用。
摘要由CSDN通过智能技术生成

1929. 数组串联
给你一个长度为 n 的整数数组 nums 。请你构建一个长度为 2n 的答案数组 ans ,数组下标 从 0 开始计数 ,对于所有 0 <= i < n 的 i ,满足下述所有要求:ans[i] == nums[i]
ans[i + n] == nums[i],具体而言,ans 由两个 nums 数组 串联 形成。返回数组 ans 。
示例 1:输入:nums = [1,2,1],输出:[1,2,1,1,2,1],解释:数组 ans 按下述方式形成:
- ans = [nums[0],nums[1],nums[2],nums[0],nums[1],nums[2]]
- ans = [1,2,1,1,2,1]
示例 2:输入:nums = [1,3,2,1],输出:[1,3,2,1,1,3,2,1],解释:数组 ans 按下述方式形成:
- ans = [nums[0],nums[1],nums[2],nums[3],nums[0],nums[1],nums[2],nums[3]]
- ans = [1,3,2,1,1,3,2,1]
提示:n == nums.length,1 <= n <= 1000,1 <= nums[i] <= 1000

#include <stdio.h>
#include <stdlib.h>
int* getConcatenation(int* nums, int numsSize, int* returnSize) {
    *returnSize = 2 * numsSize;
    int* ans = (int*)malloc(*returnSize * sizeof(int));
    for (int i = 0; i < numsSize; i++) {
        ans[i] = nums[i];
        ans[i + numsSize] = nums[i];
    }
    return ans;
}
int main() {
    int nums[] = {1, 2, 1};
    int numsSize = sizeof(nums) / sizeof(nums[0]);
    int returnSize;
    int* ans = getConcatenation(nums, numsSize, &returnSize);
    printf("Output: ");
    for (int i = 0; i < returnSize; i++) {
        printf("%d ", ans[i]);
    }
    printf("\n");
    
    free(ans);
    
    return 0;
}
定义一个名为`getConcatenation`的函数,它接受一个整数数组`nums`、数组大小`numsSize`和一个指向整数的指针`returnSize`。该函数返回一个长度为`2 * numsSize`的整数数组`ans`,其中`ans`由两个`nums`数组串联形成。
在`main`函数中,我们定义了一个示例数组`nums`,然后调用`getConcatenation`函数来获取答案数组`ans`。最后,我们打印输出`ans`数组的元素。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值