取模运算符在数组下标的应用

news2025/2/26 20:10:19
  • 什么是取模运算符%?

定义:

a mod b,设a、b属于正整数且b>0,如果q、r属于正整数满足a=q*b+r,且0≤r<b,则定义:

a mod b = r

注意:取模运算符两侧的除数被除数都是整数,不能是小数。如果你将小数带入运算,编译器可能会出现以下报错,例如 1% 0.5 :

想要很好地利用%,我们就先要了解一下取模运算符的运算性质:

  • 模运算的应用

1. 将下标控制在一定的范围

根据取模运算的运算性质,模运算结果的范围是 0 ~ (除数-1)。反过来就是,如果你想将数据控制在 0 ~ x ,你就可以 %(x+1)。

2. 利用当前下标获取前一个元素

我们想要获取当前下标的前一个时,可能会出现这两种种情况:当前下标是第一个下标时,那么它对应的前一个数据就是下标为末尾的元素;其他情况下,可以直接用当前下标-1来获得前一个元素。例如,当前下标为0时,它对应的前一个元素就是下标为7的元素;当前下标为2时,它对应的前一个元素就是下标为2-1=1的元素

那么我们如何利用%来实现这一个过程呢? 

这里我先给出答案在做出解释:

i = (x+size)%(size+1),这里 i 代表最终下标,x代表当前下标,size代表数组的最后一个下标(注意不是数组长度)

  • 分析:

根据我们的需求,我们想要x经过%运算后能够变为x-1,并且在特殊情况下,x=0可以变成x等于最后一个下标,再根据取模运算的性质,(x+size)%(size+1)可以写成((x-1)+size+1)%(size+1)-->  (x-1)%(size+1)+(size+1)%(size+1),因为 (x-1)一定小于(size+1),所以前半部分的运算结果就是(x-1),后半部分运算结果为0,最终结果就是(x-1)。

其实,主要思想就是将 x 配凑成 x-1,那么可能会有疑惑:为什么不把x直接减一进行运算呢?

事实上,这里有一点需要注意:取模运算 mod 是可以满足的,我们使用%运算主要想应对的就是下标为零的情况,当下标为零时,直接减一,会变成 -1 mod(size+1),这里就涉及负数作为被除数的运算:

在数学中,余数通常定义为非负整数,所以最终答案是1(运算-13 = (-2)*7 + 1),我们会发现这样不就满足我们的需求了吗,例如:(0-1)%(4+1)= 4 ( -1 = (-1)*(4+1) + 4)。

但是,在编程中,通常取模运算(%)的结果会保持符号与被除数一致。这是因为在计算机中,% 运算符会根据被除数的符号来确定余数的符号。所以如果你在编译器上运算这个式子,答案会是-6,因为编译器在运算时会先将负号去掉进行计算:13%7=6,最终的结果会根据被除数的符号确定,因为被除数(-13)是负数,所以最终的答案是-6.

所以,我们不能通过直接减一达到我们想要的效果,而是通过加上一个size来配凑。

 3. 利用当前下标获取下一个元素

我们想要获取当前下标的下一个时,可能会出现这两种种情况:当前下标是最后一个下标时,那么它对应的下一个数据就是下标为0的元素;其他情况下,可以直接用当前下标+1来获得下一个元素。例如,当前下标为7时,它对应的下一个元素就是下标为0的元素;当前下标为2时,它对应的下一个元素就是下标为2+1=3的元素

这里我先给出答案在做出解释:

i = (x+1)%(size+1),这里 i 代表最终下标,x代表当前下标,size代表数组的最后一个下标;

如果你看懂了,上面我第一个的分析,那么你也能够理解这个式子是怎么来的。


本次内容到此结束了!如果你觉得这篇博客对你有帮助的话 ,希望你能够给我点个赞,鼓励一下我。感谢感谢……

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/915758.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

中秋节思维导图怎么绘制?教你使用这种绘制方法

中秋节思维导图怎么绘制&#xff1f;中秋节是中国传统的一个重要节日&#xff0c;许多人会在这一天与家人、朋友聚在一起庆祝&#xff0c;品尝月饼、猜灯谜、赏月等。中秋节作为一个具有浓厚文化底蕴的节日&#xff0c;其历史文化知识十分丰富&#xff0c;而通过绘制思维导图&a…

Three.js 实现模型材质局部辉光(发光,光晕)效果和解决辉光影响场景背景图显示的问题

1.Three.js 实现模型材质局部辉光&#xff08;发光&#xff0c;光晕&#xff09;效果 2.解决辉光效果影响场景背景图显示的问题 相关API的使用&#xff1a; 1. EffectComposer&#xff08;渲染后处理的通用框架&#xff0c;用于将多个渲染通道&#xff08;pass&#xff09;组…

iPhone 14 Pro 动态岛的功能和使用方法详解

当iPhone 14 Pro机型发布时,苹果公司将软件功能与屏幕顶部的药丸状切口创新集成,称之为“灵动岛”,这让许多人感到惊讶。这篇文章解释了它的功能、工作原理,以及你如何与它互动以执行动作。 一、什么是灵动岛?它是如何工作的 在谣言周期的早期‌iPhone 14 Pro‌ 在宣布时…

只考一门数据结构,计算机学硕复录比1:1的山东双非学校考情分析

青岛理工大学 考研难度&#xff08;☆&#xff09; 内容&#xff1a;23考情概况&#xff08;拟录取和复试分析&#xff09;、院校概况、23专业目录、23复试详情、各专业考情分析、各科目考情分析。 正文1420字&#xff0c;预计阅读&#xff1a;3分钟 2023考情概况 青岛理工…

Linux下的系统编程——基础操作(一)

前言&#xff1a; linux系统编程是基于Linux系统进行程序开发的一个过程&#xff0c;主要涉及到的是linux系统中的函数使用如下图所示&#xff1a; 最外层的是咱们的应用程序&#xff0c;这部分程序大多调用的是咱们标准库&#xff0c;或者说是C库&#xff0c;这部分库函数能…

PDF中的表格怎么转换为Excel?这两个工具一定得收藏!

PDF是一种常见的文件格式&#xff0c;它可以保持文件的原始样式和内容&#xff0c;但是也有一些缺点&#xff0c;比如不易编辑和处理数据。如果你想要将PDF中的表格或数据导出到Excel中&#xff0c;以便进行分析、计算或制作图表&#xff0c;那么你可能需要一个专业的PDF转Exce…

Window异常提示:“为了对电脑进行保护,已经阻止此应用”

目录 1.Window异常提示图片&#xff1a; 2.家庭版额外需要执行的解决方式&#xff1a; 3.本地组策略编辑器(后续家庭版和专业版一致) 4.禁用后重新启动电脑就可以正常运行程序了 1.Window异常提示图片&#xff1a; 2.家庭版额外需要执行的解决方式&#xff1a; 代码&#xff…

超纯水中硼离子去除,特种除硼树脂CH-99

超纯水是指水中杂质含量极低的一种水质&#xff0c;其中矢量硼是一种常见的杂质。矢量硼的存在会影响超纯水的质量&#xff0c;因此需要采取一定的方法去除。 常用的去除矢量硼的方法有离子交换法、反渗透法和电化学法等。 电化学法&#xff1a; 是一种利用电化学反应对水中…

Java JDBC学习教程

Java JDBC JDBC 独立于数据库JDBC 不独立于SQLJDBC 不适用于非关系数据库流行的关系数据库JDBC 教程范围JDBC 核心概念JDBC 示例加载JDBC驱动程序打开数据库连接创建语句更新数据库查询数据库关闭数据库连接 Java JDBC API&#xff08;Java Database Connectivity&#xff09…

无涯教程-PHP - preg_grep()函数

preg_grep() - 语法 array preg_grep ( string $pattern, array $input [, int $flags] ); 返回由与给定模式匹配的输入数组元素组成的数组。 如果将flag设置为PREG_GREP_INVERT&#xff0c;则此函数返回输入数组中与给定模式不匹配的元素。 preg_grep() - 返回值 返回使用…

8路光栅尺磁栅尺编码器或16路高速DI脉冲信号转Modbus TCP网络模块 YL99-RJ45

特点&#xff1a; ● 光栅尺磁栅尺解码转换成标准Modbus TCP协议 ● 高速光栅尺磁栅尺4倍频计数&#xff0c;频率可达5MHz ● 模块可以输出5V的电源给光栅尺或传感器供电 ● 支持8个光栅尺同时计数&#xff0c;可识别正反转 ● 可以设置作为16路独立DI高速计数器 ● 可网…

vue 简单实验 v-bind 变量与html属性绑定

1.代码 <script src"https://unpkg.com/vuenext" rel"external nofollow" ></script> <div id"bind-attribute"><span v-bind:title"message">鼠标悬停几秒钟查看此处动态绑定的提示信息&#xff01;</sp…

“产业应用创新奖2023”启动征集

当前&#xff0c;人工智能已经成为新一轮科技革命和产业变革的重要驱动力量&#xff0c;基于强算法、大算力和大数据的大模型成为主流方向。文心大模型和飞桨一直致力于发挥算法模型技术优势&#xff0c;助力AI 大生产加速升级。 文心飞桨赋能千行百业 产业创新不断涌现 数字医…

你做的可视化大屏老被老板嫌弃丑?那是你没掌握这7个动态效果!

数据可视化大屏成为了最近的爆火需求&#xff0c;自从老李我在朋友圈发了一条关于可视化大屏的朋友圈&#xff0c;客户、亲戚、朋友、同学都过来问我这种可视化大屏是怎么做出来的&#xff0c;要花多少钱&#xff1f; 老李也很实诚&#xff0c;直接跟他们说&#xff0c;免费&a…

概率论与数理统计:第七章:参数估计 第八章:假设检验

文章目录 Ch7. 参数估计7.1 点估计1.矩估计2.最大似然估计(1)离散型(2)连续型 7.2 评价估计量优良性的标准(1)无偏性 (无偏估计)(2)有效性(3)一致性 7.3 区间估计1.置信区间、置信度2.求μ的置信区间 Ch8. 假设检验1.拒绝域α、接受域1-α、H₀原假设、H₁备择假设2.双边检验、…

初识 JVM 01

JVM JRE JDK的关系 JVM 的内存机构 程序计数器 java指令的执行流程&#xff1a; 1 右侧的java源代码编译为左侧的java字节码&#xff08;右侧第一个方块对应左侧第一个方块&#xff09; 2 字节码 经过解释器 变为机器码 3 机器码就可以被cpu来执行 程序计数器的作用就…

Linux学习之samba服务

yum install -y samba安装samba。 安装完成如下&#xff1a; /etc/samba/smb.conf是samba配置文件&#xff0c;内容如下&#xff1a; # See smb.conf.example for a more detailed config file or # read the smb.conf manpage. # Run testparm to verify the config is cor…

亿发智能定制系统规范食品饮料行业质量管理,ERP解决方案助力业务增长

随着食品生产业态的不断复杂化和食品风险的逐渐凸显&#xff0c;食品饮料生产商面临着更大的挑战和机遇,需要与时俱进&#xff0c;借助数字化手段建立完整的质量管理体系&#xff0c;有效降低食品事故的风险。同时&#xff0c;面对数字化时代&#xff0c;食品饮料生产商需要一套…

正则表达式一小时学完

闯关式学习Regex 正则表达式&#xff0c;我感觉挺不错的&#xff0c;记录一下。 遇到不会的题&#xff0c;可以评论交流。 真的很不错 链接 Regex Learn - Step by step, from zero to advanced.