Leetcode——数组的旋转

编程入门 行业动态 更新时间:2024-10-25 06:24:18

Leetcode——<a href=https://www.elefans.com/category/jswz/34/1771288.html style=数组的旋转"/>

Leetcode——数组的旋转

189. 轮转数组

class Solution {
public:void rotate(vector<int>& nums, int k) {int len=nums.size();vector<int> num(len);for(int i=0;i<len;i++){num[(i+k)%len]=nums[i];}nums.assign(num.begin(),num.end());}
};

旋转数组

没看出数学公式gg
正确答案

class Solution {
public:int maxRotateFunction(vector<int>& nums) {int f = 0, n = nums.size();int numSum = accumulate(nums.begin(), nums.end(), 0);for (int i = 0; i < n; i++) {f += i * nums[i];}int res = f;for (int i = n - 1; i > 0; i--) {f += numSum - n * nums[i];res = max(res, f);}return res;}
};

超时答案

class Solution {
public:int maxRotateFunction(vector<int>& nums) {int len=nums.size();int max=0x80000000;for(int i=0;i<len;i++){int sum=0;for(int j=0;j<len;j++){sum+=nums[j]*((j+i)%len);}if(sum>max){max=sum;}}return max;}
};

更多推荐

Leetcode——数组的旋转

本文发布于:2023-12-08 00:18:09,感谢您对本站的认可!
本文链接:https://www.elefans.com/category/jswz/34/1672072.html
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。
本文标签:数组   Leetcode

发布评论

评论列表 (有 0 条评论)
草根站长

>www.elefans.com

编程频道|电子爱好者 - 技术资讯及电子产品介绍!