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

【力扣】整数反转,判断是否溢出的数学解法

整数反转原题地址

方法一:数学

反转整数

如何反转一个整数呢?考虑整数操作的3个技巧:

  1. xmod10 可以取出 x 的最低位,如 x=123 , xmod10=3 。
  2. x/=10 可以去掉 x 的最低位,如 x=123 , x/=10 , x=12 。
  3. x=x*10+y 可以在 x 后面续上 y ,其中 y 是一位数,如 x=123 , y=4 , x=x*10+y , x=1234 。

假设要反转的整数为 x ,反转后的整数存储在变量 rev 中, rev 一开始初始化为 0 ,那么反复执行以下操作:

  1. digit=xmod10 ,取出 x 的最低位数。
  2. x/=10 ,去掉 x 的最低位数。
  3. rev=rev*10+digit ,在 rev 后面续上 digit 。

直到 x 为 0 为止,此时 rev 存储的数据符合题目要求。

判断溢出

问题在于,如何判断插入后的数据是否超出 [INT_MIN,INT_MAX] 的范围,导致溢出?

我们来探索不等式 INT\_MIN\leqslant n\leqslant INT\_MAX 成立的充分必要条件。

先看右半边,即 n\leqslant INT\_MAX 。

对于任意整数 i ,我们有 i=\left \lfloor \frac{i}{10} \right \rfloor\times 10+i mod 10 ,如对于 123 , 123/10=12 , 123mod10=3 , 123=12*10+3 。

不等式化为: \left \lfloor \frac{n}{10} \right \rfloor\times 10+n mod 10=\left \lfloor \frac{INT\_MAX}{10} \right \rfloor\times 10+INT\_MAX mod 10 ,带入 INT\_MAXmod10=7 , \left \lfloor \frac{n}{10} \right \rfloor=rev , nmod10=digit , 0\leqslant digit\leqslant 9 

移项化简得: (rev-\left \lfloor \frac{INT\_MAX}{10} \right \rfloor)\times 10\leqslant 7-digit ,记 \left \lfloor \frac{INT\_MAX}{10} \right \rfloor=m ,

  1. 当 rev=m 时,如果还要推入数字,那么 digit≤2 ,因为 INT_MAX 的最高位为 2 ,此时不等式左边等于 0 ,右边为正数,不等式恒成立。
  2. 当 rev>m 时,不等式左边至少是 10 ,右边至多是 7 ,不等式恒不成立。
  3. 当 rev<m 时,不等式左边至多是 -10 ,右边至少是 7-9=-2 ,不等式恒成立。

所以原不等式右半边成立的充分必要条件是 rev\leqslant m ,即 rev\leqslant\left \lfloor \frac{INT\_MAX}{10} \right \rfloor 。同理左半边成立的充分必要条件是 rev\geqslant \left \lceil \frac{INT\_MIN}{10} \right \rceil 。

原不等式成立的充分必要条件是 \left \lceil \frac{INT\_MIN}{10} \right \rceil\leqslant rev\leqslant\left \lfloor \frac{INT\_MAX}{10} \right \rfloor 。

// 方法一:数学
class Solution
{
public:int reverse(int x){int rev = 0;while (x){if (rev < INT_MIN / 10 || rev > INT_MAX / 10){return 0;}// rev 后面续上 x 的最低位rev = rev * 10 + x % 10;// 去掉 x 的最低位x /= 10;}return rev;}
};

相关文章:

【力扣】整数反转,判断是否溢出的数学解法

整数反转原题地址 方法一&#xff1a;数学 反转整数 如何反转一个整数呢&#xff1f;考虑整数操作的3个技巧&#xff1a; xmod10 可以取出 x 的最低位&#xff0c;如 x123 &#xff0c; xmod103 。x/10 可以去掉 x 的最低位&#xff0c;如 x123 &#xff0c; x/10 &#xf…...

Jmeter之内置函数__property和__P的区别

1. __property函数 作用 读取 Jmeter 属性 语法格式 ${__property(key,var,default)} 参数讲解 小栗子 ${__property(key)} 读取 key 属性如果找不到 key 属性&#xff0c;则返回 key&#xff08;属性名&#xff09; ${__property(key,,default)} 读取 key 属性如果找不到 k…...

GPT润色指令

1. GPT润色指令 Below is a paragraph from an academic paper. Polish the writing to meet the academic style,improve the spelling, grammar, clarity, concision and overall readability. When necessary, rewrite the whole sentence. Paragraph &#xff1a;你的句子…...

Ubuntu中matplotlib显示中文的方法

其实有很多朋友已经总结得很好了&#xff1a;Ubuntu下让matplotlib显示中文字体_ubuntu matplot 使用汉字-CSDN博客 这里我就是简单补充一下&#xff1a; 按照上面这篇博客&#xff0c;下载&#xff1a;GitHub - tracyone/program_font: fonts for programmer 然后运行&#…...

String类-equals和==的区别-遍历-SubString()-StringBuilder-StringJoiner-打乱字符串

概述 String 类代表字符串&#xff0c;Java 程序中的所有字符串文字&#xff08;例如“abc”&#xff09;都被实现为此类的实例。也就是说&#xff0c;Java 程序中所有的双引号字符串&#xff0c;都是 String 类的对象。String 类在 java.lang 包下&#xff0c;所以使用的时候…...

IDEA的LeetCode插件的设置

一、下载插件 选择点击File->Setting->Plugins&#xff1a;搜索LeetCode 二、打开这个插件 选择View —>Tool Windows—>leetcode 三、登陆自己的账号 关于下面几个参数的定义&#xff0c;官方给的是&#xff1a; Custom code template: 开启使用自定义模板&…...

2024.2.29 模拟实现 RabbitMQ —— 项目展示

目录 项目介绍 核心功能 核心技术 演示直接交换机 演示扇出交换机 演示主题交换机 项目介绍 此处我们模拟 RabbitMQ 实现了一个消息队列服务器 核心功能 提供了 虚拟主机、交换机、队列、绑定、消息 概念的管理九大核心 API 创建队列、销毁队列、创建交换机、销毁交换机、…...

React htmlfor

注意&#xff0c;在添加属性时&#xff0c; class 属性需要写成 className &#xff0c;for 属性需要写成 htmlFor &#xff0c;这是因为 class 和 for 是 JavaScript 的保留字。 在React中&#xff0c;当我们需要为一个表单元素设置标签时&#xff0c;可以使用htmlFor属性。它…...

现代化数据架构升级:毫末智行自动驾驶如何应对年增20PB的数据规模挑战?

毫末智行是一家致力于自动驾驶的人工智能技术公司&#xff0c;其前身是长城汽车智能驾驶前瞻分部&#xff0c;以零事故、零拥堵、自由出行和高效物流为目标&#xff0c;助力合作伙伴重塑和全面升级整个社会的出行及物流方式。 在自动驾驶领域中&#xff0c;是什么原因让毫末智行…...

理解Stable Diffusion、LoRA、Dreambooth、Hypernetworks、Textual Inversion、Checkpoint

前言 在深度学习和人工智能的领域中&#xff0c;模型生成和调整技术的快速发展为创造性内容的自动化提供了新的可能性。本文将介绍四种重要的模型技术——Stable Diffusion、LoRA、Dreambooth、和Hypernetworks——它们在生成艺术、个性化模型调整和网络结构设计方面各自的特点…...

spring boot3登录开发-2(1图形验证码接口实现)

⛰️个人主页: 蒾酒 &#x1f525;系列专栏&#xff1a;《spring boot实战》 &#x1f30a;山高路远&#xff0c;行路漫漫&#xff0c;终有归途。 目录 前置条件 内容简介 图形验证码接口实现 导入糊涂工具依赖 接口分析 编写验证码接口 测试验证码接口 前置条件 …...

网络编程中的问题总结

1、服务端重启后bind失败&#xff0c;因为TCP 套接字状态 TIME_WAIT 引起&#xff0c;该状态在套接字关闭后约保留 2 到 4 分钟。在 TIME_WAIT 状态退出之后&#xff0c;套接字被删除&#xff0c;该地址才能被重新绑定而不出问题。可以通过setsockopt()设置Socket描述符的选项S…...

数据结构-关键路径

介绍 在AOV网的基础上&#xff0c;如果用对应边来表示活动持续时间&#xff0c;这种有向图被称为AOE网在AOE网中&#xff0c;入度为0的为源点&#xff0c;出度为0的为汇点&#xff0c;整张网看做是一件事情完成的过程&#xff0c;那么这两个点就是事情的开始和结束。每个活动持…...

进程间通信学习笔记(共享内存)

内存映射概念&#xff1a; 共享内存可以通过mmap()映射普通文件使一个磁盘文件与内存中的一个缓冲区相映射&#xff0c;进程可以像访问普通文件一样对文件进行访问&#xff0c;不必再强调read,write。 mmap的优点&#xff1a; 实现了用户空间和内核空间的高效交互方式 mmap的…...

ChatGPT学习第三周

&#x1f4d6; 学习目标 ChatGPT在各行各业的应用 探索ChatGPT在不同领域&#xff08;如教育、客户服务等&#xff09;的实际应用案例。 ChatGPT的局限性和挑战 讨论ChatGPT面临的挑战&#xff0c;包括偏见、误解及其限制。 ✍️ 学习活动 学习资料 《人工智能通用大模型(…...

R语言混合效应(多水平/层次/嵌套)模型及贝叶斯实现技术应用

回归分析是科学研究中十分重要的数据分析工具。随着现代统计技术发展&#xff0c;回归分析方法得到了极大改进。混合效应模型&#xff08;Mixed effect model&#xff09;&#xff0c;即多水平模&#xff08;Multilevel model&#xff09;/分层模型(Hierarchical Model)/嵌套模…...

[C++]使用C++部署yolov9的tensorrt模型进行目标检测

部署YOLOv9的TensorRT模型进行目标检测是一个涉及多个步骤的过程&#xff0c;主要包括准备环境、模型转换、编写代码和模型推理。 首先&#xff0c;确保你的开发环境已安装了NVIDIA的TensorRT。TensorRT是一个用于高效推理的SDK&#xff0c;它能对TensorFlow、PyTorch等框架训…...

eureka注册中心做了哪些事情/原理?

1.服务注册&#xff1a; 将eureka client发送过来的元数据存储到注册表中 2.服务续约&#xff1a; eureka client默认会每30秒向eureka server发送一次心跳来进行服务续约&#xff0c;通过这一行动来表示自己没有出现故障&#xff1b; 3.服务…...

c语言经典测试题4

1.题1 #include <stdio.h>//没有break的话&#xff0c;输入什么都会往下一直执行下去&#xff0c;而且default在最后就会全都执行 int main() {char c;int v0 0, v1 0, v2 0;do{switch (c getchar())// 输入ADescriptor{casea:caseA:casee:caseE:casei:caseI:caseo:…...

设计模式(五)-观察者模式

前言 实际业务开发过程中&#xff0c;业务逻辑可能非常复杂&#xff0c;核心业务 N 个子业务。如果都放到一块儿去做&#xff0c;代码可能会很长&#xff0c;耦合度不断攀升&#xff0c;维护起来也麻烦&#xff0c;甚至头疼。还有一些业务场景不需要在一次请求中同步完成&…...

别再手动更新依赖了!手把手教你配置GitHub Dependabot,让项目自动保持最新

解放双手&#xff1a;用GitHub Dependabot打造智能依赖更新系统 每次启动项目时看到那一长串待更新的依赖项列表&#xff0c;是不是感觉头皮发麻&#xff1f;我曾经花费整整一周时间手动更新一个中型项目的依赖&#xff0c;结果因为版本冲突不得不回滚三次。这种痛苦的经历促使…...

Whoami开发者架构解析:深入理解模块化隐私保护系统设计

Whoami开发者架构解析&#xff1a;深入理解模块化隐私保护系统设计 【免费下载链接】whoami-project Whoami provides enhanced privacy, anonymity for Debian and Arch based linux distributions 项目地址: https://gitcode.com/gh_mirrors/wh/whoami-project Whoami…...

Bioicons终极指南:3000+免费科研矢量图标如何彻底改变你的科学可视化工作流

Bioicons终极指南&#xff1a;3000免费科研矢量图标如何彻底改变你的科学可视化工作流 【免费下载链接】bioicons A library of free open source icons for science illustrations in biology and chemistry 项目地址: https://gitcode.com/gh_mirrors/bi/bioicons 你是…...

避坑指南:赛元单片机触摸库配置,SOCAPI_SET_TOUCHKEY_CHANNEL和阈值到底怎么设?

赛元单片机触摸库实战&#xff1a;从参数解析到抗干扰配置全指南 第一次接触赛元单片机的电容触摸功能时&#xff0c;面对那一堆十六进制参数和模糊的文档说明&#xff0c;我盯着示波器上跳动的信号波形整整三天没睡好觉。电机干扰导致的误触发、阈值设置不当引发的响应迟钝、…...

盟接之桥®电子数据交换EDI,如何用一套“数字桥梁”,让全球巨头主动为你敞开大门?

在全球经济一体化的宏大叙事下&#xff0c;中国制造业正站在历史的十字路口。从“中国制造”到“中国智造”&#xff0c;这不仅仅是称谓的更迭&#xff0c;更是产业链地位的跃迁。然而&#xff0c;在这条通往全球价值链高端的道路上&#xff0c;无数制造企业面临着同一个隐秘而…...

nli-MiniLM2-L6-H768快速上手:无需GPU也可运行(CPU fallback),但推荐RTX 4090 D加速

nli-MiniLM2-L6-H768快速上手&#xff1a;无需GPU也可运行&#xff08;CPU fallback&#xff09;&#xff0c;但推荐RTX 4090 D加速 1. 平台介绍 nli-MiniLM2-L6-H768 是一个轻量级自然语言推理&#xff08;NLI&#xff09;模型&#xff0c;专注于文本对关系判断、零样本文本…...

【DeepSeek】SMC 调用约定

SMC 调用遵循 ARM SMC Calling Convention (SMCCC) 规范&#xff08;文档编号&#xff1a;ARM DEN 0028&#xff09;。 这是一套标准化的“握手协议”&#xff0c;规定了非安全世界&#xff08;EL1/EL2&#xff09;如何向安全监控器&#xff08;EL3&#xff09;传递请求&#x…...

如何通过Koikatu HF Patch获得完整游戏体验:终极安装与配置指南

如何通过Koikatu HF Patch获得完整游戏体验&#xff1a;终极安装与配置指南 【免费下载链接】KK-HF_Patch Automatically translate, uncensor and update Koikatu! and Koikatsu Party! 项目地址: https://gitcode.com/gh_mirrors/kk/KK-HF_Patch 你是否对《Koikatu!》…...

中药湿疹膏

看着宝宝娇嫩的皮肤上泛起一片片红疹&#xff0c;因瘙痒而哭闹不休、夜不能寐&#xff0c;初为父母的你&#xff0c;是否感到心急如焚却又束手无策&#xff1f;湿疹&#xff0c;这个困扰着无数0-3岁婴幼儿家庭的常见皮肤问题&#xff0c;背后是家长们深深的焦虑与对安全有效产品…...

告别手动算地址!UVM验证中如何用uvm_mem_man实现C语言式的动态内存管理

UVM验证中的智能内存管理&#xff1a;用uvm_mem_man实现C语言式动态分配 在复杂SoC验证环境中&#xff0c;内存管理往往是验证工程师最头疼的问题之一。想象一下这样的场景&#xff1a;你需要为视频处理单元测试分配不同分辨率的帧缓冲区&#xff0c;同时还要为网络模块动态创建…...