当前位置: 首页 > news >正文

C语言 | Leetcode C语言题解之第457题环形数组是否存在循环

题目:

题解:

int next(int* nums, int numsSize, int cur) {return ((cur + nums[cur]) % numsSize + numsSize) % numsSize;  // 保证返回值在 [0,n) 中
}bool circularArrayLoop(int* nums, int numsSize) {for (int i = 0; i < numsSize; i++) {if (!nums[i]) {continue;}int slow = i, fast = next(nums, numsSize, i);// 判断非零且方向相同while (nums[slow] * nums[fast] > 0 && nums[slow] * nums[next(nums, numsSize, fast)] > 0) {if (slow == fast) {if (slow != next(nums, numsSize, slow)) {return true;} else {break;}}slow = next(nums, numsSize, slow);fast = next(nums, numsSize, next(nums, numsSize, fast));}int add = i;while (nums[add] * nums[next(nums, numsSize, add)] > 0) {int tmp = add;add = next(nums, numsSize, add);nums[tmp] = 0;}}return false;
}

http://www.mrgr.cn/news/42929.html

相关文章:

  • 云原生(四十六) | MySQL软件安装部署
  • C++ | Leetcode C++题解之第457题环形数组是否存在循环
  • C#串口温度读取
  • Java | Leetcode Java题解之第457题环形数组是否存在循环
  • 【设计模式】软件设计原则——接口隔离迪米特
  • CSRF 漏洞 - 学习手册
  • Java | Leetcode Java题解之第456题132模式
  • C语言高阶【2】--动态内存管理【2】--柔性数组(这是个全新的知识点,不想了解一下吗?)
  • C++入门基础知识99——【关于C++ 成员运算符】
  • Pikachu-Unsafe Fileupload-服务端check
  • etcd 快速入门
  • 【有啥问啥】SE(Squeeze-and-Excitation)架构详解
  • CUDA与TensorRT学习六:模型部署-CNN、模型部署-YOLOv8检测器、部署BEVFusion模型
  • vue-scrollto实现页面组件锚点定位
  • 最新版的dubbo服务调用(用nacos做注册中心用)
  • 【pytorch】张量求导
  • 华为杯”第十二届中国研究生数学建模竞赛-D题:单/多列车优化决策问题的研究(续)
  • 第一百零五周周报
  • 帝国CMS迁移网站后出现Create path fail: (建立目录不成功!请检查目录权限 )的解决办法
  • 中断-NVIC与EXTI外设详解(超全面)