m0_61138145 2021-11-10 11:07 采纳率: 88.2%
浏览 21
已结题

大家看一下这个简单滑动窗口问题怎么解决


#include <stdio.h>

int main(void) {
    int n, k;
    int r[50];
    int i, j;
    int min, max;

    scanf("%d %d", &n, &k);
    //存值
    for (i = 0; i < n; i++)
        scanf("%d", &r[i]);
    //固定窗口求最小值
    for (i = 0, j = i, min = r[i]; i < j + k - 1; i++) {
        if (min > r[i + 1])
            min = r[i + 1];
    }
    printf("%d", min);
    //滑动窗口求最小值
    while (i < n) {
        for (i = i - k + 1, j = i, min = r[i]; i < j + k - 1; i++) {
            if (min > r[i + 1])
                min = r[i + 1];
        }
        printf(" %d ", min);
    }
    return 0;
}

这个代码还没完全完工,做固定窗口的时候测试没有问题,但滑动部分进入死循环了,不知道是哪里出错了,希望大家给看看。本人第一次尝试做这种题,如果知道有滑动窗口更好的方法的话也可以给说一下,我会及时采纳的,谢谢~(重点是先纠正我这个代码的问题)

  • 写回答

2条回答 默认 最新

  • 从善若水 5G/6G通信领域优质创作者 2021-11-10 11:09
    关注

    如果你的 j + k - 1 小于 n,按就会死循环

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

问题事件

  • 已结题 (查看结题原因) 11月11日
  • 已采纳回答 11月11日
  • 创建了问题 11月10日

悬赏问题

  • ¥15 工创大赛太阳能电动车项目零基础要学什么
  • ¥20 limma多组间分析最终p值只有一个
  • ¥15 nopCommerce开发问题
  • ¥15 torch.multiprocessing.spawn.ProcessExitedException: process 1 terminated with signal SIGKILL
  • ¥15 QuartusⅡ15.0编译项目后,output_files中的.jdi、.sld、.sof不更新怎么解决
  • ¥15 pycharm输出和导师的一样,但是标红
  • ¥15 想问问富文本拿到的html怎么转成docx的
  • ¥15 我看了您的文章,遇到了个问题。
  • ¥15 GitHubssh虚拟机连接不上
  • ¥15 装完kali之后下载Google输入法 重启电脑后出现以下状况 且退不出去 桌面消失 反复重启没用