LeetCode刷题1929-简单-数组串联
【摘要】 LeetCode刷题1929-简单-数组串联
@[toc]
前言
算法作为极其重要的一点,是大学生毕业找工作的核心竞争力,所以为了不落后与人,开始刷力扣算法题!
第一遍,不求最优解,但求能过!!!
一、题目描述
给你一个长度为 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
二、题目解析
-
循环
给了答案数组和原数组的关系,循环数组的长度的二倍
依次往数组里面添加
判断条件
-
python列表相加
三、代码
1. java
class Solution {
public int[] getConcatenation(int[] nums) {
int n = nums.length;
int[] ans = new int[n*2];
for (int i=0;i<n*2;i++){
if (i<n){
ans[i] = nums[i];
}else{
ans[i] = nums[i-n];
}
}
return ans;
}
}
2. python
-
循环
class Solution: def getConcatenation(self, nums: List[int]) -> List[int]: ans = [0]*(len(nums)*2) for i in range(len(nums)*2): if i<len(nums): ans[i] = nums[i] else: ans[i] = nums[i-len(nums)] return ans
-
python性质
class Solution: def getConcatenation(self, nums: List[int]) -> List[int]: ans = nums*2 return ans
结语
坚持最重要,每日一题必不可少!
【声明】本内容来自华为云开发者社区博主,不代表华为云及华为云开发者社区的观点和立场。转载时必须标注文章的来源(华为云社区)、文章链接、文章作者等基本信息,否则作者和本社区有权追究责任。如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱:
cloudbbs@huaweicloud.com
- 点赞
- 收藏
- 关注作者
评论(0)