六月集训第一天——数组

今日刷题内容:数组

今天没有跟上进度,就听懂了一题,


前言

今天没有跟上进度,就听懂了一题。这是我个人的一点理解。(用C语言)

一、思路

  1. 根据k的值有三种情况,为了便于理解,直接将三种情况标明
  2. 如果k为0返回全0即可
  3. 如果k大于或小于0,分两种情况讨论,这里展开大于0的
  4. 如果i+k大于数组最右边下标,会回到数组起始开始算的第i + k - n个位置
  5. 如果小于数组最右边下标,则直接相加即可
  6. 小于0的情况也是一样

二、代码

1.引入库

题目来自力扣

代码如下(示例):求和利用循环数组特性以及加头减尾的操作,进行性能调优 - 拆炸弹 - 力扣(LeetCode)

int* decrypt(int* code, int codeSize, int k, int* returnSize){

    int i,j;

    int val = 0;

    int n = codeSize;

    int *ret=(int*)malloc(sizeof(int)*n);

    *returnSize=codeSize;

    for(i = 0;i < n;i ++){

        if(k > 0){

            val=0;

            for(j = i + 1;j <= i+k;j ++){

                val += code[j % n];

            }

        }

        else if(k < 0){

            val=0;

            for(j = i - 1;j >= i + k;j --){

                val += code[(j % n + n) % n];

            }

        }

        ret[i]=val;

    }

    return ret;

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值