LeetCode 每日一题 ---- 【1017.负二进制转换】

server/2024/10/18 8:20:25/

LeetCode 每日一题 ---- 【1017.负二进制转换】

  • 1017.负二进制转换
    • 方法一:模拟进制转换
    • 推广:任意进制转换

leetcode.cn/problems/convert-to-base-2/description/" rel="nofollow">1017.负二进制转换

方法一:模拟进制转换

我们平常做进制转换最常用的方法就是辗转相除法,下面的图示分别给出了普通的10进制转2进制的过程,和10进制转 -2进制的过程
在这里插入图片描述

这里我们来推导一下右边的计算过程的合规性。
我们设 被除数为a,除数为b,余数为c
则有 a = (-2) * b + c,当余数c等于 -1 时,那么我们就不好表示了,我们就可以在这里变形:

a = (-2) * b + c
a - (-2) * b = c
a - (-2) * b + 2 = c + 2
a - (-2) * (b + 1) = c + 2

当c == -1时,我们可以加2,转换为1,然后将辗转相除得到的b的值加1,然后继续做辗转相除的运算操作。

class Solution {public String baseNeg2(int n) {if (n == 0 || n == 1) return String.valueOf(n);StringBuilder sb = new StringBuilder();while (n != 0) {int mod = n % (-2);n /= -2;if (mod == -1) {sb.append(1);n ++ ;} else {sb.append(mod);}}return sb.reverse().toString();}
}

推广:任意进制转换

依据上面的逻辑,这个解题逻辑是可以推广到任意进制的,我们设进制为k,则我们我们辗转相除的时候,如果余数小于0,则余数- k(此时k是负数),商 + 1即可。

class Solution {public String baseNeg2(int n) {if (n == 0) {return "0";}int k = -2;int x = n;StringBuilder sb = new StringBuilder();while (x != 0) {int mod = x % k;x /= k;if (mod < 0) {// 修正一下sb.append(mod - k);++x;} else {sb.append(mod);} }return sb.reverse().toString();}
}

时间复杂度:
O(logn)

空间复杂度:
O(1)


http://www.ppmy.cn/server/25563.html

相关文章

二维码门楼牌管理应用平台:智慧城市的新引擎

文章目录 前言一、数据管理&#xff1a;打造智慧城市的数据基石二、数据应用&#xff1a;推动城市管理的智能化升级三、展望未来&#xff1a;构建更加智慧的城市管理体系 前言 随着城市化的快速推进&#xff0c;城市管理面临着前所未有的挑战。二维码门楼牌管理应用平台作为一…

机器学习学习 - 数据预处理

机器学习学习笔记 - 数据预处理 数据预处理是机器学习项目中不可或缺的一环&#xff0c;它涉及到数据的清洗、格式化、归一化、特征提取等一系列操作&#xff0c;以便为后续的模型训练和分析提供高质量的数据集。以下是关于数据预处理的一些关键步骤和注意事项。 一、数据准备…

vue2 实现echarts图表进入可视区域后再加载动画,以及 使用了resize之后,动画失效问题解决

Intersection Observer API 是一个现代的浏览器 API&#xff0c;用于监测一个或多个目标元素与其祖先元素或视窗&#xff08;viewport&#xff09;之间的交叉状态&#xff08;intersection&#xff09;的变化。它可以有效地监听元素是否进入或离开可视区域&#xff0c;从而实现…

2024年 Java 面试八股文——java框架篇

目录 1、简单的谈一下SpringMVC的工作流程 难度系数&#xff1a; 2、说出Spring或者SpringMVC中常用的5个注解 难度系数&#xff1a;⭐ 3、简述SpringMVC中如何返回JSON数据 难度系数&#xff1a;⭐ 4、谈谈你对Spring的理解 难度系数&#xff1a;⭐ 5、Spr…

战胜DALL·E 3和 Midjourney的开源模型来了——playground-v2.5

这是首次超越闭源AI模型的开源时刻。Playground AI 前不久宣布Playground v2.5正式开源。Playground v2.5 是美学质量方面最先进的开源模型&#xff0c;特别关注增强的颜色和对比度、改进的多纵横比生成以及改进的以人为中心的精细细节。并且在美学质量方面树立了新标准&#x…

蓝网科技临床浏览系统 deleteStudy SQL注入漏洞复现(CVE-2024-4257)

0x01 产品简介 蓝网科技临床浏览系统是一个专门用于医疗行业的软件系统,主要用于医生、护士和其他医疗专业人员在临床工作中进行信息浏览、查询和管理。 0x02 漏洞概述 蓝网科技临床浏览系统 deleteStudy接口处SQL注入漏洞,未经身份验证的恶意攻击者利用 SQL 注入漏洞获取…

面试的时间地点(南京坦道)工程化问题比较少,通用性问题表较多

1.前端的选型 2.前端的$nicktick&#xff08;&#xff09; 3.前端的媒体查询 4.前端的 VUE 高级用法 我的回答{ web端视图层的渲染原理 } 5.前端的数组&#xff0c;异步处理 我的回答{ 回了&#xff0c;最笨的方法。 es6的set&#xff08;&#xff09;&#xff1b; 参数是&…

设计模式(三)、模板方法设计模式

模式定义 模板方法模式(Template Method Pattern):定义一个操作中算法的框架而将一些步骤延迟到子类中&#xff0c;模板方法使得子类可以不改变一个算法的结构即可重定义该算法的某些特定步骤 模式结构 模板方法模式包含如下角色: AbstractClass: 抽象类 ConcreteClass:具体…