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;
    }
};
相关推荐
We་ct22 分钟前
LeetCode 173. 二叉搜索树迭代器:BSTIterator类 实现与解析
前端·算法·leetcode·typescript
weixin_3954489127 分钟前
main.c_0222cursor
c语言·前端·算法
sycmancia1 小时前
C++——析构函数的调用顺序、const修饰对象、类成员
开发语言·c++
Zik----1 小时前
Leetcode27 —— 移除元素(双指针)
数据结构·算法
踩坑记录1 小时前
leetcode hot100 79. 单词搜索 medium 递归回溯
leetcode
czxyvX1 小时前
010-C++11
开发语言·c++
陆嵩1 小时前
GMRES 方法的数学推导及其算法表示
算法·概率论·arnoldi·gmres·minres·givens·hessenberg
plus4s1 小时前
2月22日(94-96题)
算法
水饺编程1 小时前
第4章,[标签 Win32] :TextOut 测试案例2
c语言·c++·windows·visual studio
tianzhiyi1989sq2 小时前
C++工具库之PugiXML使用指南
java·数据库·c++