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;
    }
};
相关推荐
17(无规则自律)9 分钟前
Leetcode第二题:用 C++ 解决字母异位词分组
c++·leetcode·哈希算法
样例过了就是过了11 分钟前
LeetCode热题100 子集
数据结构·c++·算法·leetcode·dfs
I_LPL15 分钟前
day52 代码随想录算法训练营 图论专题5
java·算法·图论·并查集
jing-ya19 分钟前
day 49 图论part1
算法·深度优先·图论
free-elcmacom24 分钟前
C++三种参数传递方式:从交换函数看值、指针与引用的区别
开发语言·c++
想吃火锅100527 分钟前
【leetcode】98.验证二叉搜索树
算法·leetcode·职场和发展
一叶落43828 分钟前
【LeetCode 172】阶乘后的零(C语言详解 | 数学规律 + 对数时间复杂度)
c语言·数据结构·算法·leetcode·动态规划
自信1504130575928 分钟前
数据结构初阶——二叉树之——堆的实现
c语言·数据结构·算法
柏木乃一29 分钟前
Linux线程(8)基于单例模式的线程池
linux·运维·服务器·c++·单例模式·操作系统·线程
!停36 分钟前
数据结构算法—归并排序
数据结构·算法