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;
    }
};
相关推荐
阿Y加油吧13 小时前
力扣打卡——接雨水、无重复字符的最长子串
算法·leetcode·职场和发展
米啦啦.13 小时前
函数模板,namespace名字空间,动态内存管理,C++11新特性,
c++·动态内存管理·函数模板·c++新特性·名字空间
茉莉玫瑰花茶14 小时前
CMake 工程指南 - 工程场景(5)
开发语言·c++·cmake
handler0114 小时前
算法:字符串哈希
c语言·数据结构·c++·笔记·算法·哈希算法·散列表
琪蘤14 小时前
点胶换阀高度标定计算说明
算法
handler0114 小时前
算法:查并集
开发语言·数据结构·c++·笔记·学习·算法·c
plus4s14 小时前
3月19日(进阶10)
算法
Trouvaille ~14 小时前
【优选算法篇】快速排序模型——从数组划分到快速选择
算法·leetcode·青少年编程·面试·蓝桥杯·快速排序·基础入门
Wect14 小时前
LeetCode 918. 环形子数组的最大和:两种解法详解
前端·算法·typescript
圣保罗的大教堂14 小时前
leetcode 3212. 统计 X 和 Y 频数相等的子矩阵数量 中等
leetcode