题目
示例 1:
输入:n = 5
输出:[-7,-1,1,3,4]
解释:这些数组也是正确的 [-5,-1,1,2,3],[-3,-1,2,-2,4]。
示例 2:
输入:n = 3
输出:[-1,0,1]
示例 3:
输入:n = 1
输出:[0]
思路解法
本题思路就是N个唯一整数,应该分为技术和偶数。若是偶数个,那么一半正数一半负数即可,若是奇数个,则再加上零即可。
class Solution {
public:
vector sumZero(int n) {
vector ans;
for(int i=1;i<=n/2;++i){
ans.push_back(i);
ans.push_back(-i);
}
if(n%2){
ans.push_back(0);
}
return ans;
}
};
注意这里不能对vector进行初始化,若是vector ans(n);那么系统会默认将前n个元素置位0.就不能用push_back函数,而是需要对前n个下表的容器元素操作,即ans[0]~ans[n];