本文已参与「新人创作礼」活动,一起开启掘金创作之路。
本题考察数组相关知识,为简单题1929.数组串联
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
代码
法1
class Solution:
def getConcatenation(self, nums) :
n = len(nums)
for i in range(n):
nums.append(nums[i])
return nums
法2
class Solution:
def getConcatenation(self, nums) :
a = nums
nums.extend(a)
return nums
解析
这个题也太简单了吧,感觉这个题才是简单题应该有的样子啊,纯纯的小白也会写啊,虽然我也是一个小白,希望我以后遇到的都是这么简单的题。
这个题是我当年刚刚开始刷leetcode第一天时写的,我是纯纯的野路子,完全没有系统的学什么是数组,for循环都写不利索,虽然没有怎么刻苦的努力,但是在这几个月里,我真的是进步了!
简单的说这个题就是把输入的数组重复两遍然后输出,蠢一点的方法就是用个for循环挨个append进去,还可以直接用函数extend,a.extend(b)就是把数列b拼接到数列a后面,生成一个新的数列。
来源:力扣(LeetCode)
链接:leetcode.cn/problems/co…