本文主要是介绍leetcode 1652.拆炸弹,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
这道题没有什么明确的做法,我们其实可以根据数组的思想来做。
一般来说是一个循环数组的话,我们可以用while来处理。
如果循环次数很少,我们可以用一种思想,那就是把原先的数组再复制一份放在后面,这样就相当于是循环了。这里就用了这种思想进行处理的,然后根据题目模拟就行了。
上代码:
class Solution {
public:vector<int> decrypt(vector<int>& code, int k) {int n=code.size();vector<int>res;if(n){if(k==0){for(int i=0;i<n;i++){res.push_back(0);}}else if(k>0){for(int i=0;i<n;i++){code.push_back(code[i]);}for(int i=0;i<n;i++){int sum=0;for(int j=i+1;j<i+1+k;j++){sum+=code[j];}res.push_back(sum);}}else{for(int i=0;i<n;i++){code.push_back(code[i]);}for(int i=n;i<code.size();i++){int haha=0;for(int j=i-1;j>=i-abs(k);j--){haha+=code[j];}res.push_back(haha);}}}return res;}
};
这篇关于leetcode 1652.拆炸弹的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!