码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • leecode #加一#二进制求和


    题目描述:

    给定一个由 整数 组成的 非空 数组所表示的非负整数,在该数的基础上加一。

    最高位数字存放在数组的首位, 数组中每个元素只存储单个数字。

    你可以假设除了整数 0 之外,这个整数不会以零开头。

    分析:对数组 digits 进行一次逆序遍历,找出第一个不为 9 的元素,将其加一并将后续所有元素置零即可。如果有若干个9,则在某末尾第一个不为9的加一,之后置零。如果digits 中所有的元素均为 9,我们需要返回一个比digits多1的新的数组

    代码:

    1. class Solution:
    2. def plusOne(self, digits: List[int]) -> List[int]:
    3. n = len(digits)
    4. for i in range(n - 1, -1, -1):
    5. if digits[i] != 9:
    6. digits[i] += 1
    7. for j in range(i + 1, n):
    8. digits[j] = 0
    9. return digits
    10. # digits 中所有的元素均为 9
    11. return [1] + [0] * n

    range(3,3)  不执行 

    [1] + [0] * 4 相当于 [10000]

    题目描述:给你两个二进制字符串 a 和 b ,以二进制字符串的形式返回它们的和。

    分析;1、将二进制转十进制,求和,结果再转成二进制

            2、不用加减乘除,通过位运算

    代码:

    1. class Solution:
    2. def addBinary(self, a, b) -> str:
    3. return '{0:b}'.format(int(a, 2) + int(b, 2))

    ‘{ 0:b}’ . format()用法:

    b、d、o、x分别表示二进制,十进制,八进制,十六进制

    int()用法:

    int(a,base) a可以是字符串或数字,base表示视当前a的类型,最后转化成整数10进制

    1. class Solution:
    2. def addBinary(self, a, b) -> str:
    3. x, y = int(a, 2), int(b, 2)
    4. while y:
    5. answer = x ^ y
    6. carry = (x & y) << 1
    7. x, y = answer, carry
    8. return bin(x)[2:]

    & :按位与

    <<:按位左移

    bin(): 返回一个整数 int 或者长整数 long int 的二进制表示

     

  • 相关阅读:
    springboot-基础-eclipse配置+helloword示例
    远程调用(REST和RPC)
    拓扑排序的应用之杂务
    JuiceFS 新手必知 24 问
    【Linux】进程等待
    竞赛 深度学习 机器视觉 车位识别车道线检测 - python opencv
    jmeter负载测试中如何找到最大并发用户数(实战)
    Opencv cuda版本编译
    Java集合框架之Vector源码分析
    【小波能量BP】基于小波能量系数提取和BP神经网络的检测算法matlab仿真
  • 原文地址:https://blog.csdn.net/weixin_44267765/article/details/127934991
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号